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)!='';

查询结果:

相关推荐
それども9 分钟前
DELETE 和 TRUNCATE TABLE区别
java·数据库·mysql
wenha12 分钟前
数据库隔离级别
数据库·mysql·sqlserver·隔离级别
2401_8714928519 分钟前
Layui如何修改Layui默认的UI主题颜色(换肤功能实现)
jvm·数据库·python
Edward111111111 小时前
4.27mysql ,数据库,数据源
数据库·mysql
小徐敲java1 小时前
踩坑实录:MySQL8.0 导入SQL报错 2006 - MySQL server has gone away 完美解决
数据库·sql
别来无恙blwy1 小时前
windows MongoDB升级-自动升级脚本-自动检测升级到任意版本
数据库·windows·mongodb
步辞1 小时前
Redis如何利用LFU算法优化缓存命中率
jvm·数据库·python
~小先生~1 小时前
sqlserver 外键、级联使用
数据库·sqlserver
forEverPlume1 小时前
golang如何实现日志按级别过滤_golang日志按级别过滤实现教程
jvm·数据库·python
m0_624578592 小时前
MySQL主从复制支持跨版本吗_不同版本间同步的注意事项
jvm·数据库·python