HIVE常用正则函数(like、rlike、regexp、regexp_replace、regexp_extract)

Oralce中regex_like和hive的regexp对应

select regexp_like('JFAF','^[JKN]') -- 以J或K或N开头 -- oracle,impala语法

select 'JFAF' regexp '^[JKN]'; -- hive语法

LIKE

语法1: A LIKE B

语法2: LIKE(A, B)

操作类型: strings

返回类型: boolean或null

描述: 如果字符串A或者字符串B为NULL,则返回NULL;如果字符串A符合表达式B的正则语法,则为TRUE;否则为FALSE。B中字符"_"表示任意单个字符,而字符"%"表示任意数量的字符。

hive>select'football' like '%ba';OKfalse
 
 
hive>select'football' like '%ba%';OKtrue
 
 
hive>select'football' like '__otba%';OKtrue
 
 
hive>selectlike('football','__otba%');OKtrue

RLIKE

语法1: A RLIKE B

语法2: RLIKE(A, B)

操作类型: strings

返回类型: boolean或null

描述: 如果字符串A或者字符串B为NULL,则返回NULL;如果字符串A符合JAVA正则表达式B的正则语法,则为TRUE;否则为FALSE。

hive>select'football' rlike 'ba';OKtrue
 
 
hive>select'football' rlike '^footba';OKtrue
 
 
hive>selectrlike('football','ba');OKtrue

Java正则:

"." 任意单个字符

"*" 匹配前面的字符0次或多次

"+" 匹配前面的字符1次或多次

"?" 匹配前面的字符0次或1次

"\d" 等于 [0-9],使用的时候写成'\d'

"\D" 等于 [^0-9],使用的时候写成'\D'

hive>select'does' rlike 'do(es)?';OKtrue

hive>select'\\';
OK
\

hive>select'2314' rlike '\\d+';OKtrue

REGEXP

语法1:AREGEXP B
语法2:REGEXP(A, B)
操作类型: strings
返回类型: boolean或null
描述: 功能与RLIKE相同

hive>select'football' regexp 'ba';OKtrue


hive>select'football' regexp '^footba';OKtrue


hive>selectregexp('football','ba');OKtrue


语法:regexp_replace(string A,string B,string C)
操作类型: strings
返回值:string
说明: 将字符串A中的符合java正则表达式B的部分替换为C。

hive>selectregexp_replace('h234ney','\\d+','o');OK
honey

REGEXP_REPLACE

语法: regexp_replace(string A, string B, string C)

操作类型: strings

返回值: string

说明: 将字符串A中的符合java正则表达式B的部分替换为C。

hive>selectregexp_replace('h234ney','\\d+','o');OK
honey

REGEXP_EXTRACT

语法: regexp_extract(string A, string pattern, int index)

返回值: string

说明:将字符串A按照pattern正则表达式的规则拆分,返回index指定的字符,index从1开始计。

hive>selectregexp_extract('honeymoon','hon(.*?)(moon)',0);OK
honeymoon
 
 
hive>selectregexp_extract('honeymoon','hon(.*?)(moon)',1);OK
ey
 
 
hive>selectregexp_extract('honeymoon','hon(.*?)(moon)',2);OK
moon

作者:多彩海洋

链接:https://www.jianshu.com/p/3bcc06b1294b

来源:简书

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值