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错误的其中一种原因,有误请留言,欢迎讨论

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值