• 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>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

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

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

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

  • 相关阅读:
    java中操作字符串有哪些类呢?
    学习笔记-Suricata
    网易严选,使用uni-app实现,包含后台数据文件
    Autosar MCAL MCU配置时钟-基于cfg
    TypeScript(3)基础类型
    有效学习,通过PMP考试
    Mybatis:Mybatis获取参数值的两种方式(4)
    A-Level数学高分笔记
    数学笔记查阅
    el-form动态检验rules
  • 原文地址:https://blog.csdn.net/weixin_41657954/article/details/125523586