Dragon
主机之家测评主机之家测评  2019-08-22 13:25 主机之家测评 隐藏边栏 |   抢沙发  102 
文章评分 0 次,平均分 0.0

我们知道在 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 判断。

本文为原创文章,版权归所有,欢迎分享本文,转载请保留出处!

发表评论

扫一扫二维码分享