sql中判断一个字段是否包含一个数据的方法有哪些?

目录

一、like模糊查询(like关键字)

二、locate(字符串,字段名)

[三、 instr(字段名,字符串)](#三、 instr(字段名,字符串))

[四、regexp_extract(subject, pattern, index)](#四、regexp_extract(subject, pattern, index))

以下是几种方法,使用hive来举例演示一下:

sql 复制代码
-- 举例:创建一个表
CREATE TABLE employee (
    name STRING,
    age INT
);

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

问题:查询名字里带 "i" 的人

一、like模糊查询(like关键字)

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

查询结果:

二、locate(字符串,字段名)

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

sql 复制代码
select * from employee where locate('i',name)>0 ;

查询结果:

三、 instr(字段名,字符串)

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

sql 复制代码
select * from employee where instr(name,'i')>0 ;

查询结果:

四、regexp_extract(subject, pattern, index)

说明:

  • subject是要判断的字段名;
  • pattern是要匹配的字符串;
  • 0表示从整个匹配结果中获取整个字串。

如果返回的字符串不为空,则说明匹配到了,即包含字符串'i',否则不包含。

sql 复制代码
select * from employee where regexp_extract(name,'i',0)!='';

查询结果:

相关推荐
sinat_383437362 小时前
Laravel 8 中实现错误日志与调试日志分离的完整配置指南
jvm·数据库·python
sunshine88511 小时前
财务RPA的深水区应用:超越自动化,迈向智能决策支持
数据库
efir OONA11 小时前
MySQL数据库误删恢复_mysql 数据 误删
数据库·mysql·adb
zhangchaoxies11 小时前
如何在 Go 中安全复制接口指针所指向的值
jvm·数据库·python
陈陈CHENCHEN12 小时前
【数据库】MySQL 8.0.40 至 8.0.44 RPM 方式升级指南
数据库·mysql
m0_7349497913 小时前
怎么利用Navicat进行调整备份文件压缩等级_详细配置与操作步骤
jvm·数据库·python
T.i.s13 小时前
番外续2-MIT-BIH Arrhythmia Database
数据库
有味道的男人13 小时前
AI 效率翻倍:对接 1688 拍立淘接口,商品全量信息一键抓取
数据库
m0_7411733313 小时前
如何处理SQL中的NULL值_使用ISNULL或COALESCE函数
jvm·数据库·python
志栋智能14 小时前
超自动化巡检:解锁运维数据的深层价值
运维·服务器·数据库·自动化