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

数据库 专栏收录该内容
2 篇文章 0 订阅

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

  • 0
    点赞
  • 0
    评论
  • 0
    收藏
  • 打赏
    打赏
  • 扫一扫,分享海报

参与评论
请先登录 后发表评论~
©️2021 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页

打赏作者

海绵鲍勃Q

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值