我们知道在 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 判断。
声明:1、本博客不从事任何主机及服务器租赁业务,不参与任何交易,也绝非中介。博客内容仅记录博主个人感兴趣的服务器测评结果及一些服务器相关的优惠活动,信息均摘自网络或来自服务商主动提供;所以对本博客提及的内容不作直接、间接、法定、约定的保证,博客内容也不具备任何参考价值及引导作用,访问者需自行甄别。2、访问本博客请务必遵守有关互联网的相关法律、规定与规则;不能利用本博客所提及的内容从事任何违法、违规操作;否则造成的一切后果由访问者自行承担。3、未成年人及不能独立承担法律责任的个人及群体请勿访问本博客。4、一旦您访问本博客,即表示您已经知晓并接受了以上声明通告。







