当我们要查询id为1,2,3,4的数据的时候,可以用 IN操作,例如:
1 SELECT * from table where id in (1,2,3,4);
这时我有另外一个表里面的字段为A,存储的值为1,2,3,4,把它作为条件去查询的时候,那么语句就变成了
1 SELECT * from table where id in (‘1,2,3,4’);
结果只能查到一条id为1的数据,想要查询4条数据怎么办呢。find_in_set派上用场了。
语法:FIND_IN_SET(str,strlist)
假如字符串str 在由N个子链组成的字符串列表strlist 中,则返回值的范围在 1 到 N 之间。一个字符串列表就是一个由一些被‘,’符号分开的自链组成的字符串。如果第一个参数是一个常数字符串,而第二个是type SET列,则 FIND_IN_SET() 函数被优化,使用比特计算。如果str不在strlist 或strlist 为空字符串,则返回值为 0 。如任意一个参数为NULL,则返回值为 NULL。这个函数在第一个参数包含一个逗号(‘,’)时将无法正常运行。
用法:select find_in_set('1','1,2,3,4');
结果是1。
这个时候就好办了,把查询语句改为:
1 SELECT * from table where FIND_IN_SET(id,'1,2,3,4')
查询结果就是id为1,2,3,4这四条数据