2015-01-21 43 views
-1

我试图执行下面的plsql程序,但是面对错误类型的表达式。任何人都可以让我知道什么可能是错误?错误类型的表达式oracle错误

CREATE OR REPLACE PROCEDURE CLN_TBL (CTRLM IN VARCHAR2, CTG IN VARCHAR,SBCT IN NUMBER, RTDT IN NUMBER)  
AS  
    V_SQL VARCHAR(2000); 
    V_TABLE VARCHAR(30);  
    CURSOR TBL_CUR  
    IS  
    SELECT TGT_TABLE_NAME FROM ODS_USER.CLNP WHERE CONTROLM=CTRLM AND  APPL_CTGY=CTG AND APPL_SUB_CTGY= SBCT;  
    L_TGT_TABLE_NAME TBL_CUR%ROWTYPE;  
BEGIN  
    OPEN TBL_CUR;  
    LOOP  
     FETCH TBL_CUR INTO L_TGT_TABLE_NAME;  
     V_TABLE:= L_TGT_TABLE_NAME ;  
     EXIT WHEN TBL_CUR%NOTFOUND;  
     V_SQL:='DELETE FROM '||V_TABLE||' WHERE RPT_DT_ID'||'=:1';  
     EXECUTE IMMEDIATE V_SQL using RTDT;  
    END LOOP;  
    COMMIT;  
    CLOSE TBL_CUR; 
END; 
+0

在这里,你不能像分配'V_TABLE:= L_TGT_TABLE_NAME',这是一个'ROWTYPE'属性'varchar'是Oracle非法的。这里不需要动态查询,除非你的表名是动态的,你可以直接从表中删除它。 – Exhausted 2015-01-21 12:57:40

回答

0

已经用尽说,你不能指定行变量为varchar所以你应该把TGT_TABLE_NAME从行变量,如下面应该工作;

CREATE OR REPLACE PROCEDURE CLN_TBL (CTRLM IN VARCHAR2, CTG IN VARCHAR,SBCT IN NUMBER, RTDT IN NUMBER)  
AS  
V_SQL VARCHAR(2000); 
V_TABLE VARCHAR(30);  
CURSOR TBL_CUR  
IS  
SELECT TGT_TABLE_NAME FROM ODS_USER.CLNP WHERE CONTROLM=CTRLM AND  APPL_CTGY=CTG AND APPL_SUB_CTGY= SBCT;  
L_TGT_TABLE_NAME TBL_CUR%ROWTYPE;  
BEGIN  
OPEN TBL_CUR;  
LOOP  
    FETCH TBL_CUR INTO L_TGT_TABLE_NAME;  
    V_TABLE:= L_TGT_TABLE_NAME.TGT_TABLE_NAME ;  
    EXIT WHEN TBL_CUR%NOTFOUND;  
    V_SQL:='DELETE FROM '||V_TABLE||' WHERE RPT_DT_ID'||'=:1';  
    EXECUTE IMMEDIATE V_SQL using RTDT;  
END LOOP;  
COMMIT;  
CLOSE TBL_CUR; 
END;