Oracle中in长度限制报错问题如何处理
导读:这篇文章主要给大家介绍“Oracle中in长度限制报错问题如何处理”的相关知识,下文通过实际案例向大家展示操作过程,内容简单清晰,易于学习,有这方面学习需要的朋友可以参考,希望这篇“Oracle中in长度限制报错问题如何处理”文章能对大家有...
这篇文章主要给大家介绍“Oracle中in长度限制报错问题如何处理”的相关知识,下文通过实际案例向大家展示操作过程,内容简单清晰,易于学习,有这方面学习需要的朋友可以参考,希望这篇“Oracle中in长度限制报错问题如何处理”文章能对大家有所帮助。发现问题
在oracle中,in的最大条数是1000条,当超过1000条就会报错:
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长度限制报错问题如何处理的知识,欢迎关注网络,网络将为大家推送更多相关知识点的文章。
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: Oracle中in长度限制报错问题如何处理
本文地址: https://pptw.com/jishu/650150.html