来源:http://www.jb51.net/article/125744.htm

测试SQL:
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(IN):
sql = select * from `test` where 'daodao' IN (`list`);  #得到结果空值.  
mysql中In是比较等不等,此处‘list'是表中的一个字段,也就是变量,除非它的值刚好和name的值一样,否则返回的结果都为空。拿test1来说,也即把‘daodao,xiaohu,xiaoqin' 改为 ‘daodao'才会匹配到第一条记录。 
test2 (FIND_IN_SET):
sql = select * from `test` where FIND_IN_SET('daodao',`list`); #得到三条数据。
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的语句执行顺序分析

最新文章

  1. js事件绑定及深入
  2. C#.NET 通用控件数据源绑定类
  3. Python的50个模块,满足你各种需要
  4. 【2016-08-18】转载:总结C++中几种结构体初始化的方法
  5. Camera中对焦模式总结
  6. [备忘]Visio中连接线交叉时跨线小弯的去掉方法
  7. 【贪心】XMU 1061 Ckp的约会
  8. Directx11学习笔记【六】 基本的数学知识----矩阵篇
  9. DIV+CSS特殊符号的处理方法
  10. Cocos2D与SpriteBuilder的问题在哪提问
  11. Android初级教程:屏幕分辨率
  12. 带着萌新看springboot源码13(手写一个自己的starter)
  13. LockSupport的源码实现原理以及应用
  14. Java_IO_文件的续写_小笔记
  15. 从零开始学 Web 之 jQuery(五)操作元素其他属性,为元素绑定事件
  16. python Polygon模块安装
  17. RAD Studio XE2破解、安装、试用
  18. Spring所需的Jar包下载
  19. Nginx下SSL证书设置和反向代理
  20. 《剑指offer》— JavaScript(22)从上往下打印二叉树

热门文章

  1. Nginx下配置Http Basic Auth
  2. 《Java 8 in Action》Chapter 12:新的日期和时间API
  3. element-ui 组件 el-calendar 农历显示问题
  4. robotframework安装与详解
  5. 洛谷题解 P1292 【倒酒】
  6. FPGA分频与倍频的简单总结(涉及自己设计,调用时钟IP核,调用MMCM原语模块)
  7. jQuery XSS漏洞
  8. Android一个简单的自定义对话框制作
  9. JAVA类变量、类方法
  10. ABP前端-关于不同按钮调用同一事件传入的参数变为相同的数据