正则表达式regexp_extract 函数

函数:regexp_extract(str, regexp[, idx]) ----字符串正则表达式解析函数
参数解释:
其中:
str是被解析的字符串或字段名

regexp 是正则表达式

idx是返回结果 取表达式的哪一部分 默认值为1。

0表示把整个正则表达式对应的结果全部返回

1表示返回正则表达式中第一个() 对应的结果 以此类推

注意点:
要注意的是idx的数字不能大于表达式中()的个数。

小例子:
1) select regexp_extract(‘hitdecisiondlist’,’(i)(.*?)(e)’,0) ;

得到的结果为:

itde

2) select regexp_extract(‘hitdecisiondlist’,’(i)(.*?)(e)’,1) ;

得到的结果为:

i

3) select regexp_extract(‘hitdecisiondlist’,’(i)(.*?)(e)’,2) ;

得到的结果为:

td

案例场景:
因为项目关键字匹配,需要按业务需求截取字段,故需要用到正则表达式帮忙实现
例如下面的字段:有3部分组成,而我需要的只是前面的2部分,因为数字数量没有规律性,所以需要用正则帮忙截取:
在这里插入图片描述
写入:select regexp_extract(xxx_skuid,’(.-.)-(.)’,1) from table 就可以得到以下只有两部分的字段了,
在这里插入图片描述
不过此时还没有结束,因为字段里面的字符串有的没有‘-’,但是也要返回原来的值,类似这种:
在这里插入图片描述
此时就需要判断字符串中是否含有‘-’了,以下
SELECT regexp_extract(xxx_skuid,
case when locate(’-’,xxx_skuid)=0 then '(.
)’ else ‘(.)-(.)’ end,1) as a
from table
用了一个判断函数locate,可自行百度看下用法。

  • 9
    点赞
  • 42
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值