Oracle如何实现两个逗号分割的字符串以及获取交集、差集
这篇文章主要介绍了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如何实现两个逗号分割的字符串以及获取交集、差集”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。