Oracle 正则 文本中有第一组表达式从第一组开始截取,否则从第二组开始截取

在工作中遇到这样一个问题:

从大段文本中利用正则表达式截取:如果有第一组表达式则从第一组表达式开始截取,如果没有,从第二组表达式开始

例如:

SELECT * FROM 
(SELECT '该患者进行了EGFR中的20#外显子检测' diag_desc FROM dual 
UNION ALL
SELECT '患者进行了20#检测' FROM dual)

对于第一条数据:需要从此文本中截取EGFR开始到20#结束

对于第二条数据:需要从此文本中截取20#

两个正则表达式或者的关系可以满足,

eg:

SELECT 
diag_desc,
regexp_substr(diag_desc,'EGFR.*?20#|20#') reg_sub 
FROM 
(SELECT '该患者进行了EGFR 20#外显子检测' diag_desc FROM dual 
UNION ALL
SELECT '患者进行了20#检测' FROM dual)

 可以满足,但用了或者关系,两个正则拼接,在大数据量的情况下,效率较低。后咨询同事得知还有另一种写法:

SELECT 
diag_desc,
regexp_substr(diag_desc,'(EGFR.*)?20#') reg_sub 
FROM 
(SELECT '该患者进行了EGFR 20#外显子检测' diag_desc FROM dual 
UNION ALL
SELECT '患者进行了20#检测' FROM dual)

 思想:利用EGFR.*为一组为A组,利用?匹配0次或一次,1次的话肯定包含A组,0次的话不包含A组直接从20#开始截取

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值