Oracle中用regexp_substr()切分截取查询到的字符串

本文介绍了数据库查询中REGEXP_SUBSTR函数的用法,包括参数含义及实例应用。通过示例展示了如何从XML格式的数据中提取特定信息,并利用该函数进行字符串的截取和拼接,最终得到期望的输出格式。适用于需要处理复杂字符串格式的场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、REGEXP_SUBSTR

REGEXP_SUBSTR(String, pattern, position, occurrence, modifier)
string:需要进行正则处理的字符串
pattern:进行匹配的正则表达式
position:起始位置,从字符串的第几个字符开始正则表达式匹配(默认为1) 注意:字符串最初的位置是1而不是0
occurrence:获取第几个分割出来的组(分割后最初的字符串会按分割的顺序排列成组)
modifier:模式(‘i’不区分大小写进行检索;‘c’区分大小写进行检索。默认为’c’)针对的是正则表达式里字符大小写的匹配

二、使用举例

本例子截取查询出的结果比如“周凯(empid:e2a2de88-52b6-4646-b7c0-e99ddad4f2aa);”,截取括号里面的内容,然后在截取出的内容中前后添加拼接的字符串
想要的效果为“‘empid:e2a2de88-52b6-4646-b7c0-e99ddad4f2aa’,”

SELECT 
       extractvalue(r.row_data, '/root/row/HR0019_Worker_num') as AUTHORNUM1,
       '''' ||
       regexp_substr(extractvalue(r.row_data, '/root/row/HR0019_Worker_num'),
                     '[^(,)]+',
                     1,
                     2) || '''' || ',' as AUTHORNUM2
  FROM dat_table_row r
 WHERE r.table_id = 'dynamicRowsIdParticipation'
   AND r.document_id = 'docid:352ab14a-b2bd-4965-89f3-3f307bb7a228';

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值