在 hiveSQL 中判断一个字段是否包含某个值

在 hiveSQL 中判断一个字段是否包含某个值是在写sql时经常遇到的问题,本文将通过下述案例用五种方法进行解决

数据准备:

题目:查找姓名中含有"i"的员工信息

复制代码
CREATE TABLE employee (
    name STRING,
    age INT
);

INSERT INTO employee VALUES
    ('Alice', 25),
    ('Bob', 30),
    ('Charlie', 35),
    ('David', 40);

方案一:like

复制代码
select * from employee where name like "%i%";

方案二:rlike

如果需要使用正则表达式来匹配复杂的模式,可以使用rlike

复制代码
select * from employee where name rlike ".*i.*";

方案三:locate(字符串,字段名)

  • locate返回某个字符串在某个字段中第一次出现的位置,如果要是没有找到,返回0

  • 可以用返回值是否为0来判断一个字段是否包含某个值

    select locate('i',name) from employee;
    select * from employee where locate('i',name) != 0;

方案四:instr(字段名,字符串)

  • 返回某个字符串在某个字段中第一次出现的位置,如果要是没有找到,返回0

  • 和 locate的区别是先写列名再写要查找的字符串

    select instr(name,'i') from employee;
    select * from employee where instr(name,'i') != 0;

方案五:regexp_extract

可以使用regexp_extract(subject, pattern, index)函数来提取字符串中匹配指定正则表达式的字串。要判断一个字符串中是否包含字串"ABCD",可以使用如下代码

subject是要判断的字符串,pattern;是要匹配的字串,index表示从整个匹配结果中获取整个字串。如果返回的字串不为空,则说明匹配到了,即包含字串'pattern',否则不包含。你需要将your_table替换为你实际使用的表名或子查询

复制代码
select *,regexp_extract(name,'i',0) from employee where regexp_extract(name,'i',0) = 'i';
相关推荐
·薯条大王37 分钟前
MySQL联合查询
数据库·mysql
careybobo1 小时前
海康摄像头通过Web插件进行预览播放和控制
前端
TDengine (老段)2 小时前
TDengine 中的关联查询
大数据·javascript·网络·物联网·时序数据库·tdengine·iotdb
杉之3 小时前
常见前端GET请求以及对应的Spring后端接收接口写法
java·前端·后端·spring·vue
喝拿铁写前端3 小时前
字段聚类,到底有什么用?——从系统混乱到结构认知的第一步
前端
morris1313 小时前
【redis】redis实现分布式锁
数据库·redis·缓存·分布式锁
再学一点就睡3 小时前
大文件上传之切片上传以及开发全流程之前端篇
前端·javascript
hycccccch3 小时前
Canal+RabbitMQ实现MySQL数据增量同步
java·数据库·后端·rabbitmq
这个懒人4 小时前
深入解析Translog机制:Elasticsearch的数据守护者
数据库·elasticsearch·nosql·translog
木木黄木木4 小时前
html5炫酷图片悬停效果实现详解
前端·html·html5