Mysql 中 IN条件为字符串时被自动截取

IN 条件只能是数字 当 IN 条件为字符串会被自动截取,导致查出的数据不对问题.下面举例子

正确:select * from test where id in (1,2,3,4,5);  
错误:select * from test where id in ('1,2,3,4,5');   -- 只会查id = 1 的数据

解决方法

使用 FIND_IN_SET()函数就能达到预期的效果,问题就解决了.
查到MYSQL中的FIND_IN_SET()函数,下面是关于FIND_IN_SET()函数的基本介绍说明

语法:FIND_IN_SET(str,strlist)

定义:

  1. 假如字符串str在由N子链组成的字符串列表strlist中,则返回值的范围在1到N之间。

  2. 一个字符串列表就是一个由一些被‘,'符号分开的自链组成的字符串。

  3. 如果第一个参数是一个常数字符串,而第二个是typeSET列,则FIND_IN_SET()函数被优化,使用比特计算。

  4. 如果str不在strlist或strlist为空字符串,则返回值为0。

  5. 如任意一个参数为NULL,则返回值为NULL。这个函数在第一个参数包含一个逗号(‘,’)时将无法正常运行。

strlist:一个由英文逗号“,”链接的字符串,例如:“a,b,c,d”,该字符串形式上类似于SET类型的值被逗号给链接起来。

示例:SELECT FIND_IN_SET(‘b’,‘a,b,c,d’); //返回值为2,相当于从1开始的索引.

select * from test where FIND_IN_SET(id,'1,2,3,4,5');  

这样就实现跟IN条件 一样的效果了.

FIND_IN_SET这个函数返回的结果不是布尔值为什么可以当做条件?

这个问题没查到原因,不过自己去尝试下,发现 select * from where 1 select * from where 5 等等数字 这些条件都是成立,值都是 true
而 MySQL中 true,false,TRUE,FALSE,它们分别代表1,0,1,0 .
多次测试发现只要条件不是 0 的数字都是 true,也包含负数 (有可能这是mysql 的骚操作吧,如果知道这个是什么原因的大哥在下面留个言吧!谢谢)

你可能感兴趣的:(MySql)