我们知道在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判断。
未经允许不得转载:吾爱主机之家 » MySQL中find_in_set查询字段中是否包含指定字符串