在 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';
相关推荐
2509_9408802217 小时前
MySQL Workbench菜单汉化为中文
android·数据库·mysql
胖头鱼的鱼缸(尹海文)17 小时前
数据库管理-第399期 Oracle 19c搭建DG Far Sync日志备库(20260107)
数据库·oracle
Vic1010117 小时前
华为云高斯数据库:gsqlexec用法
java·大数据·数据库·postgresql·华为云
pas13617 小时前
28-mini-vue customRender
前端·javascript·vue.js
REDcker17 小时前
web 端 H265 软解码实现原理与使用说明
前端·音视频·播放器·h265·解码·软解码
techdashen17 小时前
MySQL体系架构 - 简洁版
数据库·mysql·架构
+VX:Fegn089517 小时前
计算机毕业设计|基于springboot + vue旅游网系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
倚栏听风雨17 小时前
深度拆解:从 npm install 到手写一个全局 CLI 工具
前端
梁正雄17 小时前
linux服务-MariaDB 10.6 Galera Cluster 部署
android·数据库·mariadb
VX:Fegn089517 小时前
计算机毕业设计|基于springboot + vue小区居民物业管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计