没有合适的资源?快使用搜索试试~ 我知道了~
Mysql中FIND_IN_SET()和IN区别简析
1 下载量 129 浏览量
2020-09-09
13:13:36
上传
评论
收藏 61KB PDF 举报
温馨提示
试读
1页
主要介绍了Mysql中FIND_IN_SET()和IN区别简析,设计实例代码,具有一定参考价值。需要的朋友可以了解。
资源推荐
资源详情
资源评论
Mysql中中FIND_IN_SET()和和IN区别简析区别简析
主要介绍了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的语句执行顺序分析等,希望对大家有所帮助。欢迎大家留言交流
讨论,如有不足之处,小编会及时改正补充。
资源评论
weixin_38665122
- 粉丝: 3
- 资源: 943
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功