ORACLE存储过程in关键字使用


一、问题描述:写了一个存储过程(只取了半截,能说明命题即可)在调用这个存储过程的时候,如果参数centerIds只有一个数字,例如:1 可以正常执行,但是如果有多个数字的话,例如:1,2,3,4,5 就回报如下错误,Procedure execution failedORA-01722: 无效数字ORA-06512: 在 “CRM3TEST.MONTH_RPT_CENTER_STU_DATA_PROC”, line 17ORA-06512: 免费云主机域名在 line 1
查询时间: 0.029s
二、解决过程通过百度发现,存储过程把这个参数作为了一个整体来处理了,并不象普通的sql一样,把他作为一个数组来对待
三、解决方案百度了一下,发现网上方案挺多,但是我选择了以下的方案,就是自定义一个函数,对这个参数进行处理。步骤一、新建一个oracle变量:(普通的sql查询窗口既可以创建)步骤二、新建一个函数(这个函数是网上现成的,亲测可用)
步骤三、改造存储过程(将原先的 in (centerIds) 更改为: in (select * from table (strsplit(centerIds))) )到此,问题解决。

相关推荐: Buffer busy waits

Buffer busy waits 一: B uffer busy waits 说明 二: B uffer bus y waits 解决思路 三: B uffer busy waits 重现过程 四: B uffer busy waits 官方文档 一: B …

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 01/03 11:27
下一篇 01/03 11:34