位置: 编程技术 - 正文

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

  • 研发活动计入当期损益怎么计算
  • 财务报表审计的标准
  • 鲜花虫草开发票属于什么类别?
  • 应收账款余额百分比法会计分录
  • 增值税发票认证平台
  • 税控盘锁死提示什么
  • 其他应付款无法支付规定
  • 外单位人员报销差旅费会计分录
  • 房产证印花税如何计算
  • 抵扣增值税怎么抵扣
  • 冲减以前年度多计的管理费用分录
  • 行政单位基建账统一核算
  • 收购个人独资企业的税收
  • 开发票零税率和免税是一样的意思吗
  • 房地产开发企业资质管理规定
  • 营业额和营业收入怎么填写
  • 总公司资金转入私人账户
  • 个人缴付的年金是什么
  • pos机刷卡手续费谁承担
  • 公会经费开支范围
  • mac怎么访问路径
  • 坏账会计处理方法
  • 虚增成本调增还会被处罚吗
  • 冲销多计提个税怎么做账
  • 苹果mac电脑自带的软件
  • linux系统中配置网卡ip地址的命令为
  • PHP:Memcached::prepend()的用法_Memcached类
  • 结转损益类收入账户的余额会计分录
  • 废旧物资经营单位增值税税率
  • 使用vscode开发vue例子
  • 盒子模型的概念
  • 基于深度学习的图像超分辨率——综述
  • vue项目兼容ie9以上浏览器
  • 软件的摊销期限
  • php连接mysql8.0
  • 笨办法学python 3电子书下载
  • 厂区租赁 法律规定
  • 帝国cms使用手册
  • mysql需要转义的特殊字符
  • mongo groupby
  • 影响公司股利分成的因素
  • 增值税发票税率1%
  • 个体户核定征收开票额度是多少
  • 发票做账流程
  • 固定资产的折旧账务处理
  • 个体工商户怎样申报个税流程
  • 异地房产税如何收
  • 应付账款数字太大咋办
  • 收到供应商的赔偿款要开票吗
  • 电子银行承兑汇票
  • 建筑企业收到材料发票没有备注工程地址可以用吗
  • 多发了工资怎么做账务处理
  • 合伙企业所得税率
  • 金税盘不申报会不会罚款
  • 预缴的税款抵扣有时间限制吗
  • sql导入和导出数据
  • mysql中字符串类型
  • sqlserver2000数据库连接不上
  • iTunesHelper.exe是什么进程?iTunesHelper.exe系统错误怎么解决?
  • wan 微型端口
  • 文件选项夹在哪里
  • xp系统能用谷歌吗
  • windows 7的用户类型
  • win8删除文件很慢
  • win8如何进入bios
  • win7系统谷歌浏览器打不开网页
  • python基本用法
  • html中<
  • Node.js中的全局对象有
  • jquery可编辑表格插件
  • 会用python
  • javascript怎么学
  • 总体把握是什么意思
  • javascript教程 csdn
  • opencv识别结果输出
  • Python3使用requests发闪存的方法
  • android进度条对话框
  • 北京海淀大集一览表?
  • 吉林网上报税网址
  • 食堂增值服务有哪些
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设