MySQL中find_in_set查询字段中是否包含指定字符串

我们知道在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查询字段中是否包含指定字符串