Hive-sql常用正则函数

本文介绍了SQL中的like关键字用于模糊查询,例如通过`%`匹配任意数量字符,`_`匹配单个字符。同时讲解了REGEXP和RLIKE用于正则表达式匹配,以及如何使用REGEXP_REPLACE进行字符串替换和REGEXP_EXTRACT进行正则提取。这些功能在数据过滤、搜索和处理中非常实用。

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

一、like
使用场景:

  • 模糊查询然后进行剔除测试数据,例:客户名称 not like ‘%测试%’
  • 模糊查询搜索

1、%:百分号代表任意个字符
(1)查询name以“张”开头的数据:
如查询test表中如下数据:
select * from test where name like ‘张%’;

(2)查询name以“三”年结尾的数据:
select * from test where name like ‘%三’;

(3)查询name中包含“测试”的数据:
select * from test where name like ‘%测试%’;
如果要对like进行否定,前面加上not即可,
select * from test where name not like ‘%测试%’;

2、_:下划线代表一个字符
(1)查询name由两个字构成,第二个字是“斯”的数据:
select * from test where name like ‘_斯’;

(2) 查询姓名由两个字构成,第二个字不是“琪”:
select * from test where name not like ‘_琪’;

二、REGEXP和RLIKE
语法1: A REGEXP B
语法2: REGEXP(A, B)
操作类型: strings
返回类型: boolean或null
说明:如果字符串A或者字符串B为NULL,则返回NULL;如果字符串A符合JAVA正则表达式B的正则语法,则为TRUE;否则为FALSE。
注: RLIKE与REGEXP功能相同

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

hive> select regexp('football', 'ba');
true

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

hive> select 'football,basketball,volleyball' regexp 'foot|basket';
true

hive> select 'football,volleyball' regexp 'football|basket';
true

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

hive> select regexp_replace('h234ney', '\\d+', 'o');
honey

四、REGEXP_EXTRACT
语法: regexp_extract(string A, string pattern, int index)
返回值: string
说明:将字符串A按照pattern正则表达式的规则拆分,返回index指定的字符,index从1开始计。

hive> select regexp_extract('honeymoon', 'hon(.*?)(moon)', 0);
honeymoon

hive> select regexp_extract('honeymoon', 'hon(.*?)(moon)', 1);
ey
 
hive> select regexp_extract('honeymoon', 'hon(.*?)(moon)', 2);
moon

附:
Java正则:
“|” 或
“&” 与
“.” 任意单个字符
“*” 匹配前面的字符0次或多次
“+” 匹配前面的字符1次或多次
“?” 匹配前面的字符0次或1次
“\d” 等于 [0-9],使用的时候写成’\d’
“\D” 等于 [^0-9],使用的时候写成’\D’

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

hive> select '\\';
\

hive> select '2314' rlike '\\d+';
true
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值