Jika prosedur PL/SQL dikompilasi, tabel yang direferensikan secara langsung harus ada. Saya akan menganggap itu adalah SQL dinamis. Jika Anda menggunakan DBMS_SQL, maka Anda dapat menggunakan LAST_ERROR_POSITION . Jika Anda menggunakan EXECUTE IMMEDIATE, dan Anda memiliki SQL dalam variabel praktis, maka mintalah kode Anda melakukan sesuatu seperti:
begin
execute immediate v_sql;
exception
when others then
declare
v_cur BINARY_INTEGER;
begin
v_cur := dbms_sql.open_cursor;
dbms_sql.parse (v_cur, v_sql, dbms_sql.native);
exception
when others then
dbms_output.put_line (sqlerrm || ' near pos ' ||
substr(v_sql,dbms_sql.last_error_position -10,40));
dbms_sql.close_cursor (v_cur);
raise;
end;
end;