在存储过程中使用EXECUTE IMMEDIATE或者 OPEN 游标 FOR 的方式执行sql字符串时,对于字符串的控制要妥当。
CREATE OR REPLACE PROCEDURE TEST_20200603(
NM_IN VARCHAR;
RESULT_CURSOR OUT CURSOR
.......
)
IS
V_SQL VARCHAR(2000);
BECIN
V_SQL :='SELECT * FROM TAB t WHERE t.nm ='||NM_IN;
OPEN RESULT_CURSOR POR V_SOL;
end;
如果时以这种方式执行,传入的形参NM_IN没有经过转成字符串’'的形式,
就会报ORA-00972: identifier is too long的错
我在控制台打印出来时这样的
SELECT * FROM TAB t WHERE t.nm = pjh;
正解:
V_SQL :='SELECT * FROM TAB t WHERE t.nm ='''||NM_IN||'''';
控制台打印
SELECT * FROM TAB t WHERE t.nm = 'pjh';
现在就已经将参数转化为字符串的形式的值进行查询了
PS:绕了我一下午的坑,只是ORA-00972错误的其中一种原因,有误请留言,欢迎讨论