数据库教程:oracle in长度限制的两个快速解决方法

发现问题在oracle中,in的最大条数是1000条,当超过1000条就会报错:oracle in长度限制的解决方法,将列转为行 但是字符串又会有长度限制,所以参考方法二方法一:select rege

发现问题

在oracle中,in的最大条数是1000条,当超过1000条就会报错:

oracle in长度限制的两个快速解决方法

oracle in长度限制的解决方法,将列转为行 但是字符串又会有长度限制,所以参考方法二

方法一:

  select regexp_substr('17,20,23','[^,]+',1,level) as str from dual connect by level <= length('17,20,23')-length(regexp_replace('17,20,23',',','')) + 1  

这里还有一个函数:regexp_replace

  regexp_replace(source_char, pattern [, replace_string [, position [, occurrence [, match_parameter ] ] ] ] )    

source_char :需要进行处理的字符串

pattern :进行匹配的正则表达式

replace_string :替换的字符

position :从第几个字符开始正则表达式匹配。(默认为1)

occurrence :标识第几个匹配组

方法二:

  select regexp_replace(supplier, '[^0-9]') cc from (select '1' a1, '2' a2, '3' a3 from dual) t unpivot(org_id for supplier in(a1,a2,a3)) p

总结

到此这篇关于oracle in长度限制的两个快速解决方法的文章就介绍到这了,更多相关oracle in长度限制解决内容请搜索<计算机技术网(www.ctvol.com)!!>以前的文章或继续浏览下面的相关文章希望大家以后多多支持<计算机技术网(www.ctvol.com)!!>!

需要了解更多数据库技术:oracle in长度限制的两个快速解决方法,都可以关注数据库技术分享栏目—计算机技术网(www.ctvol.com)!

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/dtteaching/795366.html

(0)
上一篇 2021年9月10日
下一篇 2021年9月10日

精彩推荐