首页数据库oracle in长度限制的两个快速解决方法

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

时间2024-02-28 15:52:03发布访客分类数据库浏览951
导读:收集整理的这篇文章主要介绍了oracle in长度限制的两个快速解决方法,觉得挺不错的,现在分享给大家,也给大家做个参考。 发现问题在oracle中,in的最大条数是1000条,当超过1...
收集整理的这篇文章主要介绍了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/631629.html
Oracle中Spool命令的使用方法实例 oracle表分区的概念及操作

游客 回复需填写必要信息