MySQL里判断某个字符串是否包含某个字符串方法

MySQL里判断某个字符串是否包含某个字符串方法

前提准备

-- 建表
create table  bas_user (
 code VARCHAR(10) not null,
 name VARCHAR(50)
);
-- 造数据
insert into bas_user values('1','猴子');
insert into bas_user values('2','狮子');
insert into bas_user values('3','小白兔');
insert into bas_user values('4','老虎');
insert into bas_user values('4','小仓鼠');

使用通配符%

通配符也就是模糊匹配,可以分为前导模糊查询、后导模糊查询和全导匹配查询,适用于查询某个字符串中是否包含另一个模糊查询的场景。

SELECT * FROM bas_user WHERE `NAME` LIKE '小%';

在这里插入图片描述

使用字符串函数find_in_set()

MySQL有提供一个字符串函数find_in_set(str1,str2)函数,用于返回str2中str1所在的位置索引,如果找到了,则返回true(1),否则返回false(0),其中str2必须以半角符号的逗号【,】分割开,逗号隔开的每一个字符都是一个完整的字符串进行匹配。

SELECT * FROM bas_user WHERE FIND_IN_SET('小白兔',NAME)>0;

在这里插入图片描述
上述建表语句,不能形象的验证此函数,使用虚拟表进行验证

SELECT FIND_IN_SET('小','小,小白兔') FROM DUAL;

在这里插入图片描述

使用字符串函数locate()

MySQL还提供一个字符串函数locate(substr,str)函数,用于返回str中substr所在的位置索引,如果找到了,则返回一个大于0的数,否则返回0。

SELECT * FROM bas_user WHERE locate('小',NAME)>0;

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

胤墨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值