位置: 编程技术 - 正文

Mysql中FIND_IN_SET()和IN区别简析

编辑:rootadmin

推荐整理分享Mysql中FIND_IN_SET()和IN区别简析,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

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

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

拿上面的实验数据说话,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 之间。

Mysql中FIND_IN_SET()和IN区别简析

一个字符串列表就是一个由一些被‘,'符号分开的子链组成的字符串。如果第一个参数是一个常数字符串,而第二个是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区别简析

本文链接地址:https://www.jiuchutong.com/biancheng/348375.html 转载请保留说明!

上一篇:sql和MySQL的语句执行顺序分析(mysql与sqlyog)

下一篇:mysql通过find_in_set()函数实现where in()顺序排序

  • 一般纳税人增值税优惠政策2023
  • 小规模纳税人建筑工程增值税税率
  • 建筑工程公司收入成本怎么结转
  • 本地的住宿费怎么交
  • 农产品收购发票可以跨区域开吗
  • 常见的税收优惠
  • 二手车交易怎么办理过户手续
  • 权益性投资收益的账务处理
  • 企业用流动资金怎么做账
  • 代开劳务票税率多少?
  • 车辆购置税固定资产
  • 宣传费开票属于什么费用
  • 固定资产折旧计提完毕怎么处理
  • 产品核算会计业务流程
  • 以前年度损益调整借贷方向
  • 吊销执照公司资产怎么办
  • 外汇账户怎么开
  • 产负债表的负债项目,显示了企业所负担债务的
  • 代个人多交的社保怎么查
  • Radio.exe - Radio是什么进程 有什么用
  • 资产接收范围的确定
  • laravel批量insert
  • 简易计税办法和计税依据
  • 细说php
  • 收到职称评审费怎么做账
  • 税务机关代小规模纳税人开发票
  • 携程首页
  • tensorflow gui
  • 服务型制造收入
  • 固定资产清理销售的收入
  • js必学知识点
  • 出口没有增值税发票需要交税吗
  • 教育费附加减免政策
  • 应付账款转入营业外收入的证明
  • python mad
  • 主营业务收入登记明细账簿范本
  • 织梦标签工具
  • 己经认证的发票怎么作废
  • 研发费用成本化和费用化
  • sql server 2008 r2 express 精简版与企业版的区别
  • sqlserver2008中有那些设备
  • sql 附加数据库
  • 职工福利按工资的实付还是应付提取
  • 买赠销售账务处理
  • 电子设备计税基础
  • 增值税发票上注明的价款包含增值税吗
  • 银行支付结算管理办法
  • 劳务派遣的工资是谁发的
  • 收到商业汇票计什么科目
  • 过路费纸质发票可以抵扣增值税吗
  • 加油费不征税发票可以报销吗
  • 处置固定资产和报废固定资产区别
  • 不动产经营租赁属于什么服务
  • 长期待摊费用如何做账
  • mysql tmp_table_size和max_heap_table_size大小配置
  • mysql单表10亿
  • win10系统如何删除账户
  • winxp系统开机启动项
  • Mac怎么设置默认视频播放器
  • linux安装php7.3
  • office进程
  • mozilla是啥
  • windows10稳定版本
  • linux查看磁盘io负载
  • android应用程序的主要语言是java
  • 用python的turtle画图代码
  • Unity3D游戏开发pdf
  • unity怎么用
  • opengl中点画线算法
  • node.js最新版
  • Open quote is expected for attribute "name" associated with an element type "item".
  • listview的item
  • centos搭建php
  • nodemodules拷贝到其他目录
  • javascript工作
  • 个人取得抽奖,购车抵用,需要缴纳个人所得税吗
  • 怎么打印纳税申报单
  • 重庆沙坪坝区沙磁巷幼儿园
  • 银行买理财注意事项
  • 城市维护建设税法自2021年10月1日起施行
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设