Oracle用正则的方式循环切割字符串
需求:有一个这样子的
Str = “‘CNJ-520-180500000001|CNJ-520-181200000001|CNJ-520-190300000001|CNJ-520-190100000001|CNJ-520-181200000002’”
,然后我需要拿到每一个单号,每一个单号都要走一遍固定的逻辑。
方法:
我们需要使用oracle中的正则表达式
进行字符匹配,去掉“|”这个的特殊符号。
然后还要使用递归
子句来执行递归操作,以便于完整的操作这个字符串。
为了能够正常的执行,还需要加上一个递归条件。
这个sql大抵是这样的。
SELECT TRIM(REGEXP_SUBSTR('STR', '[^|]+', 1, LEVEL)) AS single_order
FROM dual
CONNECT BY
REGEXP_SUBSTR('STR', '[^|]+', 1, LEVEL) IS NOT NULL
AND PRIOR SYS_GUID() IS NOT NULL
START WITH 'STR' IS NOT NULL;
这里面的输出结果为:
这样子在使用游标,就可以循环拿到单号,从第一个到最后一个了。
判断一个字符串中是否包含某个字符串?
首先看到,这个里面是有三个单号,然后是有两个“|”的。
直接查某一个列,出现了这个符号多少次。
SELECT REGEXP_COUNT(indc003, '\|') 出现多少次
FROM indc_t
WHERE indcent = 99 and indcdocno = 'CNJ-D2B-202308000018'
直接查列名,也可以直接count看一下,如果大于0 就说明是存在的。
使用
- instr(indc003,‘|’) > 0
判断。