当前位置: 移动技术网 > IT编程>数据库>Mysql > Mysql中FIND_IN_SET()和IN区别简析

Mysql中FIND_IN_SET()和IN区别简析

2017年12月07日  | 移动技术网IT编程  | 我要评论
前段时间项目中使用到mysql的find_in_set函数,感觉挺好用的。过一段时间,老大找到我说,这个需要改为in,哈哈,只能改了,原因会在下面分析到! 弄个测试表

前段时间项目中使用到mysql的find_in_set函数,感觉挺好用的。过一段时间,老大找到我说,这个需要改为in,哈哈,只能改了,原因会在下面分析到!

弄个测试表来说说两者的区别,测试数据直接在问答区copy一份,能说明问题就行,哈哈,如果侵犯您的版权还请见谅,互联网吗,就需要分享!

测试代码:  
create table `test` ( 
 `id` int(8) not null auto_increment, 
 `name` varchar(255) not null, 
 `list` varchar(255) not null, 
 primary key (`id`) 
) 
insert into `test` values (1, 'name', 'daodao,xiaohu,xiaoqin'); 
insert into `test` values (2, 'name2', 'xiaohu,daodao,xiaoqin'); 
insert into `test` values (3, 'name3', 'xiaoqin,daodao,xiaohu'); 
test1:sql = select * from `test` where 'daodao' in (`list`); 
得到结果空值. 
test2:sql = select * from `test` where find_in_set('daodao',`list`); 
得到三条数据。 

拿上面的实验数据说话,test1得到的结果为空,为什么呢?因为,mysql中in是比较等不等,此处‘list'是表中的一个字段,也就是变量,除非它的值刚好和name的值一样,否则返回的结果都为空。拿test1来说,也即把‘daodao'改为‘daodao,xiaohu,xiaoqin'才会匹配到第一条记。

test2返回三条数据,可能是我们刚好需要的。mysql中find_in_set函数用来比较是不是包含,不管‘list'字段是变量或给定的字符串常量都能很好的工作。mysql中原型为:find_in_set(str,strlist)。 假如字符串str 在由n 子链组成的字符串列表strlist 中,则返回值的范围在 1 到 n 之间。

一个字符串列表就是一个由一些被‘,'符号分开的子链组成的字符串。如果第一个参数是一个常数字符串,而第二个是type set列,则   find_in_set() 函数被优化,使用比特计算。 如果str不在strlist 或strlist 为空字符串,则返回值为 0 。如任意一个参数为null,则返回值为 null。这个函数在第一个参数包含一个逗号(‘,')时将无法正常运行。str也可以是变量,比如表中的一个字段。

当然,这不是我们项目中需要将find_in_set替换为in的原因,因为在我们项目中两者都可以实现功能。只是in比find_in_set性能高。我们要查询的字段是主键,使用in时会使用索引,只会查询表中部分数据。find_in_set则会查询表中全部数据,由于数据量比较大,性能肯定不高,所以替换为in。想看查询部分还是全部,可以使用explain即解释功能查看,如果是部分则type为range(范围),全部则type为all(全部),还有个type是const,常量级的,呵呵。。。

最佳实践:

1、如果待查询的条件是常量那就使用in,是变量则使用find_in_set,可以使用索引的,貌似,哈哈。

2、如果使用in和find_in_set都能满足条件,则最好使用in,理由同上,特别是查询字段为主键时或有索引时。

3、如果使用in不能满足功能需求,那只能使用find_in_set了,哈哈,有时候说不定in中条件加个%号也可以解决问题,加个%号in就不只是比较是否相等了!

总结

以上就是本文关于mysql中find_in_set()和in区别简析的全部内容,感兴趣的朋友可以参阅:mysql数据库表分区注意事项大全【推荐】几个比较重要的mysql变量sql和mysql的语句执行顺序分析等,希望对大家有所帮助。欢迎大家留言交流讨论,如有不足之处,小编会及时改正补充。

如您对本文有疑问或者有任何想说的,请 点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网