欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Mysql中FIND_IN_SET()和IN区别简析

程序员文章站 2022-04-29 09:06:40
前段时间项目中使用到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的语句执行顺序分析等,希望对大家有所帮助。欢迎大家留言交流讨论,如有不足之处,小编会及时改正补充。