- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Oracle 两个逗号分割的字符串,获取交集、差集(sql实现过程解析)由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
Oracle数据库的两个字段值为逗号分割的字符串,例如:字段A值为“1,2,3,5”,字段B为“2”.
想获取两个字段的交集(相同值)2,获取两个字段的差集(差异值)1,3,5.
1、最终实现的sql语句 。
1、获取交集(相同值):
1
2
3
4
5
6
7
8
9
10
|
select
regexp_substr(id,
'[^,]+'
, 1, rownum) id
from
(
select
'1,2,3,5'
id
from
dual)
connect
by
rownum <= length(regexp_replace(id,
'[^,]+'
)) +1
intersect
-- 取交集
select
regexp_substr(id,
'[^,]+'
, 1, rownum) id
from
(
select
'2'
id
from
dual)
connect
by
rownum <= length(regexp_replace(id,
'[^,]+'
)) +1;
/*结果:
2
*/
|
2、获取差集(差异值):
1
2
3
4
5
6
7
8
9
10
11
12
|
select
regexp_substr(id,
'[^,]+'
, 1, rownum) id
from
(
select
'1,2,3,5'
id
from
dual)
connect
by
rownum <= length(regexp_replace(id,
'[^,]+'
)) +1
minus
--取差集
select
regexp_substr(id,
'[^,]+'
, 1, rownum) id
from
(
select
'2'
id
from
dual)
connect
by
rownum <= length(regexp_replace(id,
'[^,]+'
)) +1;
/*结果:
1
3
5
*/
|
2、实现过程用到的函数用法说明 。
1、regexp_substr 。
正则表达式分割字符串,函数格式如下:
1
2
3
4
5
6
|
function
regexp_substr(strstr, pattern [,position] [,occurrence] [,modifier] [subexpression])
__srcstr:需要进行正则处理的字符串
__pattern:进行匹配的正则表达式
__position:可选参数,表示起始位置,从第几个字符开始正则表达式匹配(默认为1)
__occurrence:可选参数,标识第几个匹配组,默认为1
__modifier:可选参数,表示模式(
'i'
不区分大小写进行检索;
'c'
区分大小写进行检索。默认为
'c'
。)
|
使用例子:
1
2
3
4
5
6
7
8
9
|
select
regexp_substr(
'1,2,3,5'
,
'[^,]+'
)
AS
t1,
regexp_substr(
'1,2,3,5'
,
'[^,]+'
,1,2)
AS
t2,
regexp_substr(
'1,2,3,5'
,
'[^,]+'
,1,3)
AS
t3,
regexp_substr(
'1,2,3,5'
,
'[^,]+'
,1,4)
AS
t4,
regexp_substr(
'1,2,3,5'
,
'[^,]+'
,2)
AS
t5,
regexp_substr(
'1,2,3,5'
,
'[^,]+'
,2,1)
AS
t6,
regexp_substr(
'1,2,3,5'
,
'[^,]+'
,2,2)
AS
t7
from
dual;
|
/*结果: 1 2 3 5 2 2 3 */ 。
2、regexp_replace 。
通过正则表达式来进行匹配替换,函数格式如下:
1
2
3
4
5
6
7
|
function
regexp_substr(srcstr, pattern [,replacestr] [,position] [,occurrence] [,modifier])
__srcstr:需要进行正则处理的字符串
__pattern:进行匹配的正则表达式
__replacestr:可选参数,替换的字符串,默认为空字符串
__position:可选参数,表示起始位置,从第几个字符开始正则表达式匹配(默认为1)
__occurrence:可选参数,标识第几个匹配组,默认为1
__modifier:可选参数,表示模式(
'i'
不区分大小写进行检索;
'c'
区分大小写进行检索。默认为
'c'
。)
|
使用例子:
1
2
3
4
5
6
7
|
select
regexp_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'
,
'[^,]+'
,
'*'
) t5
from
dual;
|
/*结果: 1,2,3,4 1,4,4,5 ,,, ,,, *,*,*,* */ 。
3、connect by 。
(1)connect by单独用,返回多行结果 。
1
|
select
rownum
from
dual
connect
by
rownum < 5;
|
/*结果: 1 2 3 4 */ 。
(2)一般通过start with . . . connect by . . .子句来实现SQL的层次查询 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
select
id,
name
,
sys_connect_by_path(id,
'\') idpath,
sys_connect_by_path(name, '
\
') namepath
from (
select 1 id, '
广东
' name, 0 pid from dual
union
select 2 id, '
广州
' name , 1 pid from dual
union
select 3 id, '
深圳'
name
, 1 pid
from
dual
)
start
with
pid = 0
connect
by
prior
id = pid;
|
/*结果: 1 广东 \1 \广东 2 广州 \1\2 \广东\广州 3 深圳 \1\3 \广东\深圳 */ 。
3、总结 。
由上面函数用法,可知下面语句可以把字符串“1,2,3,5”转换为4行记录 。
1
2
3
|
select
regexp_substr(id,
'[^,]+'
, 1, rownum) id
from
(
select
'1,2,3,5'
id
from
dual)
connect
by
rownum <= length(regexp_replace(id,
'[^,]+'
)) +1
|
然后在2个结果中使用集合运算符(UNION/UNION ALL 并集,INTERSECT 交集,MINUS 差集)进行最终处理.
总结 。
以上所述是小编给大家介绍的Oracle 两个逗号分割的字符串,获取交集、差集的sql实现过程解析,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我网站的支持! 如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢! 。
原文链接:https://www.cnblogs.com/gdjlc/archive/2019/10/23/11724187.html 。
最后此篇关于Oracle 两个逗号分割的字符串,获取交集、差集(sql实现过程解析)的文章就讲到这里了,如果你想了解更多关于Oracle 两个逗号分割的字符串,获取交集、差集(sql实现过程解析)的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我有一个字符串 "1,23,45,448.00",我想用小数点替换所有逗号,用逗号替换所有小数点。 我需要的输出是“1.23.45.448,00” 我尝试用 . 替换 , 如下: var mystri
我刚刚开始阅读 C。 情况: x = ( y = 3, ( z = ++y + 2 ) + 5 ) 它首先评估y = 3,然后评估( z =++y + 2) 我的问题: 它应该首先评估( z =++y
我是 VIM 初学者,我有一个奇怪的问题。我开始在终端模拟器中使用 vim,但今天我转向了 gVim。然后我意识到我不能在插入模式下写逗号!我试过 :map , , :imap ,都说没有找到映射。然
我上面有一个 JavaScript 正则表达式函数代码: function AcceptDigits(objtextbox) { var exp = /[^\d{1,3}]/g; ob
我需要使用 Java 的 split() 方法分割字符串。如何编写某个单词的分隔符的正则表达式模式?例如“和”? 我得到了分割空格和逗号的模式,即 [,\\s] 但我想添加单词 and ,以便它也成为
我们通常使用逗号来强调句子中的某些内容。但是说到搜索引擎优化,我只是想知道这是否有用,尤其是当标题标签或页面标题中所需的字符数有限(65到70个)以便爬虫读取时。我们是否需要使用逗号? 最佳答案 页面
我想找出每个学科学期的学生上课人数。以下是给出正确答案的查询 select semester,subject,count(stdId) from tblSubjectMaster group by s
int m = 5, d = 12, y = 1975, val; // May 12, 1975 谁能解释一下下面代码行中逗号运算符的功能/用途: val = (d+=m<3?y--:y-2
我不能在 Visual Studio 2013 中使用 Ctrl+, 和在 Windows 8.1 中使用 Pycharm。有没有办法找到哪个应用程序占用了这个快捷方式/热键? 我试过 Windows
我发现很难用谷歌搜索 powershell 中这两种执行方法调用的区别的答案。 : $member = "1.2.3.4:567" # IPaddress + port for demonstrati
谁能建议我如何在 emacs 中通过 n 逗号前进(或后退)? 我正在尝试浏览 CSV 文件 我知道我可以做类似的事情: C-u 100 M-f 但是能够在逗号上做更多的正则表达式会更准确 最佳答案
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
这是一个棘手的问题,我会尽力描述它。 我有一个文本输入,用户可以在标签中输入。 用户在输入中键入标签(例如“starcraft”)并按下逗号键后,我希望逗号之前的所有字符(即单词“starcraft”
我如何打印 csv 文件中逗号后的最后一个值,我想循环遍历该文件并打印出最后一个值: 数据: 20181016135716, 00-00-00-00-00-04, 10.0.0.1, 10.0.0.8
这个问题在这里已经有了答案: How to format the HH:mm:ss separators of a TimeSpan in a culture-aware manner? (3 个答
我想去掉除数字、$、逗号 (,) 之外的所有内容。 这只是 strip 字母 string Cadena; Cadena = tbpatronpos6.Text;
我已经在我的 xml 文件中创建了一个编辑文本。这是我的代码: 问题是在我的输出项目中它只能工作其中一个。只有点或只有逗号。怎么了 ?在模拟器中工作正常,只有在我的版本中没有。 最佳答案 我用不同
我正在尝试编写一个正则表达式来提取由空格分隔的单词(可选逗号 + 空格),从单词中删除“堆栈”前缀(如果有的话)。我正在尝试找到一个纯正则表达式解决方案,而无需对结果进行任何后处理或类似(如果可能)。
我正在尝试在数据库中插入一些数据,但遇到了一些麻烦。目前我无法将数据添加到我的表中,我不知道为什么。 我正在使用一些您不需要理解的通用方法,这适用于我的所有项目,并且在任何项目中都没有任何错误。 以下
我想从 json 中删除尾随逗号, { "key1": "value1", "object": { "key2": "value2", // <- remove comma },
我是一名优秀的程序员,十分优秀!