Oracle REGEXP_SUBSTR()函数

REGEXP_SUBSTR(String, pattern, position,occurrence, modifier)

一、参数解释
String:需要进行正则处理的字符串。
pattern:正则表达式。
position:起始位置(从字符串的第几个开始正则,默认为1,注:数据库中的字符串起始位置为1)。
occurrence:获取第几组通过正则表达式分割出来的组。
modifier:模式(‘i’不区分大小写,‘c’区分大小写。其中默认没‘c’)。

二、配合CONNECT BY使用
案例分析:
SELECT REGEXP_SUBSTR(‘四,五,六,七’,’[^,]+’,1,‘LEVEL’,‘i’) AS STR
FROM DUAL
CONNECT BY LEVEL <= LENGTH(‘四,五,六,七’) - LENGTH(REPLACE(‘四,五,六,七’),’,’,’’) + 1
结果:
在这里插入图片描述

由图可知,这里的LEVEL取值可为1,2,3,4.而通过正则表达式分割出了四组分别是四、五、六、七。即从结果可以得到,这里将第一组、第二组、第三组、第四组的表达式全部取了出来。这里的重要点就在于理解LEVEL的取值。理解后就理解了整个函数。

猜你喜欢

转载自blog.csdn.net/qq_41409803/article/details/121273681