有了FIND_IN_SET这个函数。咱们能够设计一个如:一只手机便是智能机,又是Andriod系统的。mysql
好比:有个产品表里有一个type字段,他存储的是产品(手机)类型,有 一、智能机,二、Andriod系统,三、小米系统,四、1000元如下sql
如今有条手机的记录便是1000元如下的,又是智能机,仍是Andriod的系统。ide
type中以 4,1,2的格式存储.函数
那们咱们如何用sql查找全部type中有4的1000元如下的手机呢,优化
这就要咱们的find_in_set出马的时候到了.spa
先看mysql手册中find_in_set函数的语法:设计
FIND_IN_SET(str,strlist)orm
假如字符串str 在由N个子链组成的字符串列表strlist 中,则返回值的范围在 1 到 N 之间。一个字符串列表就是一个由一些被‘,’符号分开的自链组成的字符串。若是第一个参数是一个常数字符串,而第二个是type SET列,则 FIND_IN_SET() 函数被优化,使用比特计算。若是str不在strlist 或strlist 为空字符串,则返回值为 0 。如任意一个参数为NULL,则返回值为 NULL。这个函数在第一个参数包含一个逗号(‘,’)时将没法正常运行。xml
mysql> SELECT FIND_IN_SET('b','a,b,c,d');字符串
+----------------------------+
| FIND_IN_SET('b','a,b,c,d') |
+----------------------------+
| 2 |
+----------------------------+
1 row in set (0.00 sec)
用起来很简单
就以上面我说到的状况来举例:
如下为实际应用当中的SQL语句:
select * from mobile where FIND_IN_SET('4',type);
这个就能够找出全部1000元如下手机的记录!