oracle 存储过程 执行 sql 字符串 ,字符串拼接 问题 ORA-00972查询时报错原因之一

在存储过程中使用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错误的其中一种原因,有误请留言,欢迎讨论

你可能感兴趣的:(数据库,数据库)