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;