PLSQL动态定义光标

时间:2017-06-22 12:27:58

标签: oracle stored-procedures plsql

我正在尝试创建一个接受两个表名作为参数的过程,然后将行从一个表复制到另一个表中,一次一个。我知道批量插入和SELECT INTO是更好的方法,但批量插入不起作用,因为当我一次插入多行时,表触发抛出突变错误。

我见过其他建议使用动态SQL的答案,但我仍然坚持如何定义光标。

CREATE OR REPLACE PROCEDURE TABLE_INSERT(
    donor_t IN VARCHAR2,
    empty_t IN VARCHAR2
    )
AS
    CURSOR C1 IS 
        SELECT * FROM donor_t;
BEGIN
    FOR row IN C1
    LOOP
        INSERT INTO empty_t VALUES row;
    END LOOP;
END;

如上所述编译时,编译器抛出ORA-00942: table or view does not exist.当使用硬编码的表名编译时,此函数按预期插入行,没有错误。

1 个答案:

答案 0 :(得分:1)

试试这个:

CREATE OR REPLACE PROCEDURE TABLE_INSERT(
donor_t IN VARCHAR2,
empty_t IN VARCHAR2
)
AS 
  V_SQL VARCHAR2(1000);
BEGIN
    V_SQL := 'INSERT INTO ' || empty_t || ' SELECT * FROM ' ||  donor_t;
    EXECUTE IMMEDIATE V_SQL;
END;
/