mysql中find_in_set()和in的区别

来源:互联网 发布:薪酬优化方案 编辑:程序博客网 时间:2024/05/17 03:11

首先举个例子来说: 
有个文章表里面有个type字段,它存储的是文章类型,有 1头条、2推荐、3热点、4图文等等 。
现在有篇文章他既是头条,又是热点,还是图文,type中以 1,3,4 的格式存储。那我们如何用sql查找所有type中有4的图文类型的文章呢?? 
这就要我们的 find_in_set 出马的时候到了。以下为引用的内容:

select * from article where FIND_IN_SET('4',type)

---------------------------------------------------------- 
MySQL手册中find_in_set函数的语法:
FIND_IN_SET(str,strlist)

str 要查询的字符串
strlist 字段名 参数以”,”分隔 如 (1,2,6,8)
查询字段(strlist)中包含(str)的结果,返回结果为null或记录

假如字符串str在由N个子链组成的字符串列表strlist 中,则返回值的范围在 1 到 N 之间。 一个字符串列表就是一个由一些被 ‘,’ 符号分开的子链组成的字符串。如果第一个参数是一个常数字符串,而第二个是type SET列,则FIND_IN_SET() 函数被优化,使用比特计算。 如果str不在strlist 或strlist 为空字符串,则返回值为 0 。如任意一个参数为NULL,则返回值为 NULL。这个函数在第一个参数包含一个逗号(‘,’)时将无法正常运行。

--------------------------------------------------------

 例子:
mysql> SELECT FIND_IN_SET('b', 'a,b,c,d'); 
-> 2 因为b 在strlist集合中放在2的位置 从1开始

select FIND_IN_SET('1', '1'); 返回 就是1 这时候的strlist集合有点特殊 只有一个字符串 其实就是要求前一个字符串 一定要在后一个字符串集合中才返回大于0的数 
select FIND_IN_SET('2', '1,2'); 返回2 
select FIND_IN_SET('6', '1'); 返回0

--------------------------------------------------------

注意: 
select * from treenodes where FIND_IN_SET(id, '1,2,3,4,5'); 
使用find_in_set函数一次返回多条记录 
id 是一个表的字段,然后每条记录分别是id等于1,2,3,4,5的时候 
有点类似in (集合) 
select * from treenodes where id in (1,2,3,4,5);

--------------------------------------------------------

find_in_set()和in的区别:

弄个测试表来说明两者的区别

复制代码
CREATE TABLE `tb_test` (  `id` int(8) NOT NULL auto_increment,  `name` varchar(255) NOT NULL,  `list` varchar(255) NOT NULL,  PRIMARY KEY  (`id`));
INSERT INTO `tb_test` VALUES (1, 'name', 'daodao,xiaohu,xiaoqin');INSERT INTO `tb_test` VALUES (2, 'name2', 'xiaohu,daodao,xiaoqin');INSERT INTO `tb_test` VALUES (3, 'name3', 'xiaoqin,daodao,xiaohu');
复制代码

原来以为mysql可以进行这样的查询:

SELECT id,name,list from tb_test WHERE 'daodao' IN(list); -- (一) 

实际上这样是不行的,这样只有当list字段的值等于'daodao'时(和IN前面的字符串完全匹配),查询才有效,否则都得不到结果,即使'daodao'真的在list中。

再来看看这个:

SELECT id,name,list from tb_test WHERE 'daodao' IN ('libk', 'zyfon', 'daodao'); -- (二)

这样是可以的。

这两条到底有什么区别呢?为什么第一条不能取得正确的结果,而第二条却能取得结果。原因其实是(一)中 (list) list是变量, 而(二)中 ('libk', 'zyfon', 'daodao')是常量。
所以如果要让(一)能正确工作,需要用find_in_set():

SELECT id,name,list from tb_test WHERE FIND_IN_SET('daodao',list); -- (一)的改进版

总结:
所以如果list是常量,则可以直接用IN, 否则要用find_in_set()函数。

--------------------------------------------------------

find_in_set()和like的区别:

在mysql中,有时我们在做数据库查询时,需要得到某字段中包含某个值的记录,但是它也不是用like能解决的,使用like可能查到我们不想要的记录,它比like更精准,这时候mysql的FIND_IN_SET函数就派上用场了,下面来看一个例子。

创建表并插入语句:

复制代码
CREATE TABLE users(    id int(6) NOT NULL AUTO_INCREMENT,    name VARCHAR(20) NOT NULL,    limits VARCHAR(50) NOT NULL, -- 权限    PRIMARY KEY (id));INSERT INTO users(name, limits) VALUES('小张','1,2,12'); INSERT INTO users(name, limits) VALUES('小王','11,22,32');
复制代码

 其中limits表示用户所拥有的权限(以逗号分隔),现在想查询拥有权限编号为2的用户,如果用like关键字的话,则查询结果如下:

SELECT * FROM users WHERE limits LIKE '%2%';

这样第二条数据不具有权限'2'的用户也查出来了,不符合预期。下面利用mysql 函数find_in_set()来解决。

SELECT * FROM users WHERE FIND_IN_SET(2,limits);

这样就能达到我们预期的效果,问题就解决了!

注意:mysql字符串函数 find_in_set(str1,str2)函数是返回str2中str1所在的位置索引,str2必须以","分割开。

总结:like是广泛的模糊匹配,字符串中没有分隔符,Find_IN_SET 是精确匹配,字段值以英文”,”分隔,Find_IN_SET查询的结果要小于like查询的结果。

--------------------------------------------------------

 

阅读全文
'); })();
0 0
原创粉丝点击
热门IT博客
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 长沙景嘉微 微问诊 网上问诊软件 微阻球形止回阀 微阻缓闭止回阀 弹簧微启式安全阀 微阻缓闭式止回阀 微阻缓闭蝶式止回阀 阅微草堂笔记电子书 白话阅微草堂笔记 阅微庄四合院酒店 沈微慕南深全文免费阅 阅微草堂笔记在线阅读 慕南深沈微全文免费阅读 慕南深沈微全文阅读 慕微楚墨霆全文免费阅读 楚墨霆慕微免费阅读 白微全文阅读 沈微慕南深全文阅读 一如清雨入微泥免费阅读 墨庭深楚微俏免费阅读 沈微慕南深全文免费阅读 居翠微在线阅读 楚微俏墨庭深全文免费阅读 一如清雨入微泥全文免费阅读 沈微慕南深免费阅读 少先队活动课设计方案 少先队活动课教案 安微省会 安微卫视节目表 安微综艺频道快乐无敌大pk 靖江微整 微领地 微领地网络 微颗粒借钱如何开通 微额贷app 微额贷app下载 网商贷提额申请千万别点 网商贷突然大降额要害死人 支付宝网商贷怎么提额 建行快贷提额