这篇文章主要介绍了Oracle如何实现两个逗号分割的字符串以及获取交集、差集,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

Oracle数据库的两个字段值为逗号分割的字符串,例如:字段A值为“1,2,3,5”,字段B为“2”。

想获取两个字段的交集(相同值)2,获取两个字段的差集(差异值)1,3,5。

一、最终实现的sql语句

1、获取交集(相同值):

selectregexp_substr(id,'[^,]+',1,rownum)idfrom(select'1,2,3,5'idfromdual)connectbyrownum<=length(regexp_replace(id,'[^,]+'))+1intersect--取交集selectregexp_substr(id,'[^,]+',1,rownum)idfrom(select'2'idfromdual)connectbyrownum<=length(regexp_replace(id,'[^,]+'))+1;/*结果:2*/

2、获取差集(差异值):

selectregexp_substr(id,'[^,]+',1,rownum)idfrom(select'1,2,3,5'idfromdual)connectbyrownum<=length(regexp_replace(id,'[^,]+'))+1minus--取差集selectregexp_substr(id,'[^,]+',1,rownum)idfrom(select'2'idfromdual)connectbyrownum<=length(regexp_replace(id,'[^,]+'))+1;/*结果:135*/

二、实现过程用到的函数用法说明

1、regexp_substr

正则表达式分割字符串,函数格式如下:

functionregexp_substr(strstr,pattern[,position][,occurrence][,modifier][subexpression])__srcstr:需要进行正则处理的字符串__pattern:进行匹配的正则表达式__position:可选参数,表示起始位置,从第几个字符开始正则表达式匹配(默认为1)__occurrence:可选参数,标识第几个匹配组,默认为1__modifier:可选参数,表示模式('i'不区分大小写进行检索;'c'区分大小写进行检索。默认为'c'。)

使用例子:

selectregexp_substr('1,2,3,5','[^,]+')ASt1,regexp_substr('1,2,3,5','[^,]+',1,2)ASt2,regexp_substr('1,2,3,5','[^,]+',1,3)ASt3,regexp_substr('1,2,3,5','[^,]+',1,4)ASt4,regexp_substr('1,2,3,5','[^,]+',2)ASt5,regexp_substr('1,2,3,5','[^,]+',2,1)ASt6,regexp_substr('1,2,3,5','[^,]+',2,2)ASt7fromdual;

/*结果:
1 2 3 5 2 2 3
*/

2、regexp_replace

通过正则表达式来进行匹配替换,函数格式如下:

functionregexp_substr(srcstr,pattern[,replacestr][,position][,occurrence][,modifier])__srcstr:需要进行正则处理的字符串__pattern:进行匹配的正则表达式__replacestr:可选参数,替换的字符串,默认为空字符串__position:可选参数,表示起始位置,从第几个字符开始正则表达式匹配(默认为1)__occurrence:可选参数,标识第几个匹配组,默认为1__modifier:可选参数,表示模式('i'不区分大小写进行检索;'c'区分大小写进行检索。默认为'c'。)

使用例子:

selectregexp_replace('1,2,3,5','5','4')t1,regexp_replace('1,2,3,5','2|3',4)t2,regexp_replace('1,2,3,5','[^,]+')t3,regexp_replace('1,2,3,5','[^,]+','')t4,regexp_replace('1,2,3,5','[^,]+','*')t5fromdual;

/*结果:
1,2,3,4 1,4,4,5 ,,, ,,, *,*,*,*
*/

3、connect by

(1)connect by单独用,返回多行结果

selectrownumfromdualconnectbyrownum<5;

/*结果:
1
2
3
4
*/

(2)一般通过start with . . . connect by . . .子句来实现SQL的层次查询

selectid,name,sys_connect_by_path(id,'\')idpath,sys_connect_by_path(name,'\')namepathfrom(select1id,'广东'name,0pidfromdualunionselect2id,'广州'name,1pidfromdualunionselect3id,'深圳'name,1pidfromdual)startwithpid=0connectbypriorid=pid;

/*结果:
1 广东 \1 \广东
2 广州 \1\2 \广东\广州
3 深圳 \1\3 \广东\深圳
*/

三、总结

由上面函数用法,可知下面语句可以把字符串“1,2,3,5”转换为4行记录

selectregexp_substr(id,'[^,]+',1,rownum)idfrom(select'1,2,3,5'idfromdual)connectbyrownum<=length(regexp_replace(id,'[^,]+'))+1

然后在2个结果中使用集合运算符(UNION/UNION ALL 并集,INTERSECT 交集,MINUS 差集)进行最终处理。

感谢你能够认真阅读完这篇文章,希望小编分享的“Oracle如何实现两个逗号分割的字符串以及获取交集、差集”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!