我们知道在 mysql 中可以使用 find_in_set 方式查询指定字符串在字段中的位置,具体使用方法如下:
find_in_set(str,strlist)
str 要查询的字符串
strlist 字段名,内容以”,”分隔
查询字段(strlist)中包含(str)的结果,返回结果为 null 或记录(str 位于 strlist 中的位置),如果 str 不在 strlist 中或 strlist 为空字符串,那么返回 0,如果任意一个参数为 null,那么返回 null。
示例:
select find_in_set('2', '1,2,3,4,5');
运行结果:2
那么当我们使用 find_in_set 查询字段中是否包含指定字符串时的用法如下:
select * from table where find_in_set('1',name) = 0
运行结果:返回所有不包含 1 的 name 字段。
select * from table where find_in_set('1',name) > 0
运行结果:返回所有包含 1 的 name 字段。
注意:前提是 name 字段属性设置为不是 null,否则要加上 is null 或者 is not null 判断。
声明:本文为原创文章,版权归主机之家测评所有,欢迎分享本文,转载请保留出处!