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

网络编程 2021-07-05 16:09www.168986.cn编程入门
这篇文章主要给大家介绍了关于oracle in长度限制的两个快速解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们狼蚁网站SEO优化随着长沙网络推广来一起学习学习吧

发现问题

在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 [, ourrence [, match_parameter ] ] ] ] )

source_char 需要进行处理的字符串

pattern 进行匹配的正则表达式

replace_string 替换的字符

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

ourrence 标识第几个匹配组

方法二

SELECT regexp_replace(Supplier, '[^0-9]')  FROM (select '1' a1, '2' a2, '3' a3 from dual) T UNPIVOT(_id FOR Supplier IN(a1,a2,a3)) P

到此这篇关于oracle in长度限制的两个快速解决方法的文章就介绍到这了,更多相关oracle in长度限制解决内容请搜索狼蚁SEO以前的文章或继续浏览狼蚁网站SEO优化的相关文章希望大家以后多多支持狼蚁SEO!

Copyright © 2016-2025 www.168986.cn 狼蚁网络 版权所有 Power by