oracle数据库报列表中最大表达式为1000错误

oracle数据库报列表中最大表达式为1000错误

1.解释:
这个错误是指sql中in中的参数最多不能超过1000个,这是oracle数据库这样设定的。
2.背景复现:
当在正式环境开发中,由于数据量会特别大,会遇到in()括号中的参数达到超过1000个的情况,这样的情况下,就会复现报错,其截图如下:
在这里插入图片描述
3.解决思路:
通过上述可以发现,只要in的参数保证在1000以内,那么就不会出现这个报错。所以,我们解决这个问题的核心思路就是解决避免in的参数超过1000。
4.解决方案:
我的解决方案有两种:
1.如果使用的是后台sql拼接方式:可以在in的时候,再写个if判断,当要In的参数index数值取999的模为0,就再in(放后边的数据)
2.如果使用的是xml文件写sql,用到sql动态标签,思路和方案一一样,我这里距展示方案二的代码写法:

   select name,sex,age from man where id in
        <foreach collection="idList" index="index" open="(" close=")" separator="," item="id">
            <!--防止数据超过1000报错-->
            <if test="(index % 999) == 998">
             0 )
             or id in (
             </if>
              #{id}
        </foreach>

最后的大概样子是这样的:

select name,sex,age from  man where id in (1,2,3) or id in (4,5,6) or id in (7,8,9)...

5.结语:
通过这个报错,我们会发现,有的bug是隐形的,在这个数据环境下,你的代码没有问题,但换一个数据环境,就会出问题,以后开发时,尽量多想一哈如果当前的数据量变大,会不会出现什么问题,如何去规避这个问题;最后希望我的这篇文章能给你带来帮助。

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值