位置: 编程技术 - 正文

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()顺序排序

  • 人民币报关可以吗
  • 保单的增值税发票
  • 进项都抵扣完了怎么办
  • 固定资产累计折旧是什么科目
  • 电子发票如何发给用截图发送可以吗?
  • 小规模纳税人如何开电子发票
  • 资产减值测试是什么意思
  • 股票投资会计科目
  • 民办幼儿园的经费投入
  • 营改增退税政策
  • 哪些税种可以税前扣除
  • 集体土地上的不动产证已经能查询为何房产证拿不到
  • 销项负数盖章吗
  • 汽车配件的税收编码是多少
  • 独生子女费属于什么费用
  • 合并报表怎么抵损益
  • 高新技术企业退税比例是多少
  • 包销和代销哪个风险大
  • 在建工程完工,并当日签订出租协议的会计分录
  • 破产报表日是哪一日
  • 工程结算在资产负债表的哪个科目
  • 销售购物卡如何开票
  • 远期结汇账务处理分录
  • 其他应付款转增股本
  • 持有公司股票是股东吗
  • 安全的无线连接软件
  • 党政机关接收企业赞助的规定
  • 电脑dat文件怎么打开
  • 出口商品要交增值税吗
  • oss对象储存的副本储存原则
  • 银行汇票未用退回情况说明
  • 商业汇票贴现时贴现额的大小受贴现期长短的影响
  • unet网络的优缺点
  • 劳务报酬可以扣除合理支出吗
  • 将时间序列转化为图像
  • 侧边导航栏点击后再展开
  • 开源cti
  • js 字符串 中 字符位置
  • wordpress隐藏内容付费可见
  • VUE3.0+Antdv+Asp.net WebApi开发学生信息管理系统(二)
  • python怎么自己写函数
  • 织梦模板安装详细教程
  • 增值税专票怎么交税
  • 消防设备计入什么科目
  • sql2008收缩日志文件
  • 收款金额比开票金额多怎么处理
  • 子公司没有收入,只有费用如何企业所得税汇算清缴
  • 代扣缴纳税款会计分录
  • 员工欠薪怎么办
  • 简易征收的项目进项税可以抵扣吗
  • 高新技术企业研发费用归集
  • 买公司宿舍有保障吗
  • 存货入库无法查明原因的短缺
  • 出口免费样品怎么做账
  • 收付转三种凭证的限制类型不同所以限制科目也不同
  • 企业其他应收款余额非常大的原因
  • Linux下MySQL 5.5/5.6的修改字符集编码为UTF8的方法
  • mysql 5.7.28安装
  • xp电脑如何在网页打开
  • 你一定不知道的56个历史真相
  • ubuntu 命令大全
  • 你能可能
  • dgservice.exe是什么
  • ServiceLayer.exe - ServiceLayer是什么进程 有什么用
  • Win10系统下怎么将韩语切换成简体中文?
  • javascript怎么做
  • excel password recovery5.0注册码
  • pythonweb框架有哪些
  • js移动到指定位置
  • shell脚本if用法
  • JavaScript+html5 canvas绘制缤纷多彩的三角形效果完整实例
  • python模块和包的区别
  • python的urllib
  • jquery点击事件有什么方法显示
  • 广州电子税务局官网登录入口网址
  • 广西地方税务局2018年1号公告
  • 演员个人所得税2023
  • 补贴收入有哪些
  • 税务局签合同
  • 主管单位申请书
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设