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的语句执行顺序分析等,希望对大家有所帮助。欢迎大家留言交流讨论,如有不足之处,小编会及时改正补充。
推荐阅读
-
关于MySql 和SqlServer 中left join , full join的一点区别
-
mysql中blob和text有什么区别
-
mysql中int、bigint、smallint 和 tinyint的区别详细介绍
-
php中关于mysqli和mysql区别的一些知识点分析
-
MySQL中interactive_timeout和wait_timeout的区别
-
MySQL中REPLACE INTO和INSERT INTO的区别分析
-
php中关于mysqli和mysql区别的一些知识点分析
-
浅谈MySQL存储过程中declare和set定义变量的区别
-
MySQL中interactive_timeout和wait_timeout的区别
-
MySQL存储引擎中MyISAM和InnoDB区别详解