将ROWID传递给REF光标以获取数据删除时,获得无效的标识符错误
执行下面给出的代码后,我会遇到以下错误:
“ error1:内部删除块: ora-00904 :“ ajappdameaad6hpaaf”:无效 标识符“
它不识别删除语句中的ROWID值,该块正在进入撤销器内部并为表格获取ROWID,然后无法执行同一rowID的删除语句,请帮助我如何使用此操作, rowid。
CREATE OR REPLACE PROCEDURE PROCESS_TEST (V_SCHEMA VARCHAR2, V_TAB VARCHAR2) AS
l_sql VARCHAR2 (2000);
CURSOR c_x
IS
SELECT *
FROM TEST_TAB
WHERE UPPER (SCHEMA) = UPPER (V_SCHEMA)
AND UPPER (TABLE_NAME) = UPPER (V_TAB)
AND STATUS IS NULL;
TYPE tab_names_type IS TABLE OF TEST_TAB%ROWTYPE;
tab_names tab_names_type;
l_cursor SYS_REFCURSOR;
TYPE c_1 IS TABLE OF UROWID;
tab_row c_1;
l_sql_errm VARCHAR2 (2000);
V_STATUS VARCHAR2 (1) := 'N';
BEGIN
OPEN c_x;
LOOP
FETCH c_x BULK COLLECT INTO tab_names LIMIT 1000;
EXIT WHEN tab_names.COUNT = 0;
FOR id IN tab_names.FIRST .. tab_names.LAST
LOOP
l_sql :=
'SELECT a.ROWID FROM '
|| tab_names (id).SCHEMA
|| '.'
|| tab_names (id).TABLE_NAME
|| ' a';
OPEN l_cursor FOR l_sql;
LOOP
FETCH l_cursor BULK COLLECT INTO tab_row LIMIT 1000;
EXIT WHEN tab_row.COUNT = 0;
FOR i IN tab_row.FIRST .. tab_row.LAST
LOOP
BEGIN
EXECUTE IMMEDIATE
'DELETE '
|| tab_names (id).SCHEMA
|| '.'
|| tab_names (id).TABLE_NAME
|| ' a WHERE a.ROWID = '
|| tab_row (i);
COMMIT;
V_STATUS := 'Y';
EXCEPTION
WHEN OTHERS
THEN
l_sql_errm := 'Inside Delete Block: ' || SQLERRM;
V_STATUS := 'N';
ROLLBACK;
END;
END LOOP;
END LOOP;
END LOOP;
END LOOP;
EXCEPTION
WHEN OTHERS
THEN
l_sql_errm := 'Inside Others Block: ' || SQLERRM;
V_STATUS := 'N';
ROLLBACK;
END;
I am getting the below error after executing the code given below :
"Error1: Inside Delete Block: ORA-00904: "AJAPPDAMEAAD6HPAAF": invalid
identifier"
Its not identifying the rowid value in the delete statement, the block is getting inside the refcursor and fetching the rowid for the table and then its not able to execute the delete statement for the same rowid, Please help me how to achieve this using rowid. Thanks In Advance...
CREATE OR REPLACE PROCEDURE PROCESS_TEST (V_SCHEMA VARCHAR2, V_TAB VARCHAR2) AS
l_sql VARCHAR2 (2000);
CURSOR c_x
IS
SELECT *
FROM TEST_TAB
WHERE UPPER (SCHEMA) = UPPER (V_SCHEMA)
AND UPPER (TABLE_NAME) = UPPER (V_TAB)
AND STATUS IS NULL;
TYPE tab_names_type IS TABLE OF TEST_TAB%ROWTYPE;
tab_names tab_names_type;
l_cursor SYS_REFCURSOR;
TYPE c_1 IS TABLE OF UROWID;
tab_row c_1;
l_sql_errm VARCHAR2 (2000);
V_STATUS VARCHAR2 (1) := 'N';
BEGIN
OPEN c_x;
LOOP
FETCH c_x BULK COLLECT INTO tab_names LIMIT 1000;
EXIT WHEN tab_names.COUNT = 0;
FOR id IN tab_names.FIRST .. tab_names.LAST
LOOP
l_sql :=
'SELECT a.ROWID FROM '
|| tab_names (id).SCHEMA
|| '.'
|| tab_names (id).TABLE_NAME
|| ' a';
OPEN l_cursor FOR l_sql;
LOOP
FETCH l_cursor BULK COLLECT INTO tab_row LIMIT 1000;
EXIT WHEN tab_row.COUNT = 0;
FOR i IN tab_row.FIRST .. tab_row.LAST
LOOP
BEGIN
EXECUTE IMMEDIATE
'DELETE '
|| tab_names (id).SCHEMA
|| '.'
|| tab_names (id).TABLE_NAME
|| ' a WHERE a.ROWID = '
|| tab_row (i);
COMMIT;
V_STATUS := 'Y';
EXCEPTION
WHEN OTHERS
THEN
l_sql_errm := 'Inside Delete Block: ' || SQLERRM;
V_STATUS := 'N';
ROLLBACK;
END;
END LOOP;
END LOOP;
END LOOP;
END LOOP;
EXCEPTION
WHEN OTHERS
THEN
l_sql_errm := 'Inside Others Block: ' || SQLERRM;
V_STATUS := 'N';
ROLLBACK;
END;
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
您将您的rowID值作为字符串连接到删除语句中。如果要执行此操作,则至少需要引用它,然后更正确地通过
charterowid()
urowid
value to a String):最好使用绑定变量:
或仅:
您的版本和我的版本,添加了调试,因此您实际上可以看到错误(根据您是否要继续进行;将其扔或记录;处理和交易控制表明您要继续进行,但是您仍然需要报告/可靠地记录问题 - 这意味着不使用
dbms_output
!)。You are concatenating your rowid value into the delete statement as a string. If you're going to do that you need to at least quote it, and more correctly convert it via
chartorowid()
(though you're still implicitly converting yoururowid
value to a string):It would be better to use a bind variable:
or just:
db<>fiddles of your version and my version, with debugs added so you can actually see the error (it would be better to throw or log it, depending on whether you want to carry on; the handling and transaction control suggest you want to carry on, but you still need to report/record the problem reliably - which means not using
dbms_output
!).rowID
是 string ,而不是号码。您必须将其包装到单个引号(chr(39)
)中:测试:
ROWID
is a string, not a number. You have to enclose it into single quotes (chr(39)
):Testing: