自动使用动态SQL使用游标或循环创建表过程 - PLSQL

时间:2016-12-16 17:20:30

标签: sql for-loop plsql cursor create-table

语法:PL SQL IDE:PL / SQL Developer

我正在尝试使用一系列区域代码为每个区域生成4个表。

我理解生成一个包含所有区域的表并截断并替换此表可能更有效但是根据使用所需的结构我不允许这样做。

4个区域来自特定表

SELECT DISTINCT REGION
FROM REGION_TABLE
;

动态生成这一系列表的最佳方法是什么?

我试图使用游标和循环,但我不确定将此游标集成到以下过程中的方法。

DECLARE 
CURSOR C_REGION IS
       SELECT DISTINCT REGION FROM REGION_TABLE ;
BEGIN
     FOR L_IDX IN C_REGION
     LOOP
     DBMS_OUTPUT.PUTLINE(L_IDX.C_REGION);
     END LOOP;
END;

使用上面的游标值,我如何将这些值不仅插入到Sql语句的Create Table部分中使用的表名中,而且还插入where子句中的参数

-- 4 REGIONS  - NORTH SOUTH EAST WEST, 

CREATE OR REPLACE PROCEDURE SALES_ORDER_TBL_PROC
          (
          REGION IN VARCHAR2
          , RETURNCODE OUT NUMBER
          , ERROR_MESSAGE OUT VARCHAR2
          )
            IS 
  TABLE_NAME VARCHAR2(30);
  SQL_STR VARCHAR2;
  REGION_VAR VARCHAR;          
BEGIN 
  TABLE_NAME := 'SALES_COUNT_'||REGION_VAR;
  SQL_STR := 'CREATE TABLE '||TABLE_NAME||
             ' AS 
               (
               SELECT 
                      REGION
                          , COUNT(DISTINCT MEMBER_ID) AS NUM_MBR
                      FROM INCREMENTAL_SALES_TBL
                      WHERE 1=1
                          AND REGION = '||REGION_VAR||
                          'GROUP BY REGION)' 
               ;

 EXECUTE IMMEDIATE SQL_STR ;

         RETURNCODE := 0;

 EXCEPTION WHEN OTHERS THEN

         RETURNCODE := SQLCODE;

         ERROR_MESSAGE :='ERR:Creating/Altering table '||TABLE_NAME ||'-'||SQLERRM;
END;
/

BEGIN
     SALES_ORDER_TBL_PROC;
END;

1 个答案:

答案 0 :(得分:1)

如何将DDL放入for循环中?我没有测试下面的代码,但它至少应该让你走向实现目标的道路,希望如此。

FOR rec IN (SELECT DISTINCT REGION FROM REGION_TABLE) LOOP
  EXECUTE IMMEDIATE
    'CREATE TABLE SALES_COUNT_' || UPPER(rec.region) || ' AS (
       SELECT REGION,
              COUNT(DISTINCT MEMBER_ID) AS NUM_MBR
         FROM INCREMENTAL_SALES_TBL
        WHERE REGION = ''' || rec.region || '''
        GROUP BY REGION)';
END LOOP;

我不记得在与EXECUTE IMMEDIATE连接时有什么限制,但是如果它不起作用那么就可以使用绑定变量和USING子句。