位置: 编程技术 - 正文

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

  • 亏损属于什么科目
  • 买车要交哪些税收
  • 交通费中的高速费怎么算
  • 如何合伙注册公司
  • 管理不善进项税额转出会计分录
  • 税收优惠形式包括
  • 去年购进的货物今年才收到发票
  • 应收账款对应的科目有哪些
  • 短期借款超过一年未归还转到哪会计视野
  • 投标保证金支付时间
  • 年底增值税专用发票入帐不勾选抵扣帐务处理
  • 小规模纳税季度申报
  • 所得税税负率是多少
  • 通讯费能开专票吗
  • 分支机构享受了税收优惠,是由总机构备案还是分支机构备案?
  • 进口商品买卖的关键环节
  • 受托代理资产核算
  • 收到汽车报废补贴怎么做账?
  • 付出去的款项退回怎么做账
  • 苹果手机怎么看国行还是美版
  • 会计帐务处理程序
  • linux怎么使用命令
  • 行政事业单位的营业执照叫什么
  • 费用报销流程怎么走
  • 上年度的费用今年怎么算
  • 浏览器显示英语怎么设置成中文
  • 笔记本thinkbook14
  • php语言之mysql操作
  • dghm.exe是什么程序
  • 采购合同付款违约条款怎么签
  • 超市收取进场费会计分录
  • 视同销售的会计处理怎么做?
  • 公司收取保证金违法吗
  • 空调年折旧率
  • 个人所得税法实施细则2023
  • 企业内部培训费用
  • wordpress怎么安装插件
  • 长期投资减值准备属于什么会计科目
  • 现金流量表中的现金流量包括哪些
  • SQLite Delete详解及实例代码
  • 赠送给客户的商品是否要计入费用?
  • 办公费税前扣除标准2023年
  • 进项抵扣和销项抵扣
  • 固定资产以提足金为准吗
  • 股权转让的印花税税率是多少
  • 增值税专票开具与发票专用章保管
  • 贷款转入账号
  • 企业年度财务报告的保管期限为
  • 法人代表可以兼任出纳吗
  • 航天信息何去何从
  • 房地产开发企业资质管理规定
  • 固定资产清理期末
  • mysql中自定义函数属于那个
  • windows下安装nas
  • Windows Server 2008下共享资源访问走捷径
  • ubuntu pdf编辑器
  • 系统技巧 制作流程
  • win8录音文件保存在哪
  • window预览
  • get mac
  • yosemite10.10.3beta3下载地址 os x10.10.3beta3官网下载
  • JavaScript对HTML DOM使用EventListener进行操作
  • Extjs中通过Tree加载右侧TabPanel具体实现
  • 怎样从零开始
  • opengl语言
  • bootstrap快速入门
  • python 异常处理方法
  • javascript常用函数大全
  • js的document.getelembyid
  • spring中aop实现
  • js的eval函数
  • pythonyield理解与用法
  • javascript如何学
  • 使用struts2+Ajax+jquery验证用户名是否已被注册
  • 国税发1994 关于个人所得税
  • 企业完税证明怎么查询打印
  • 关于抓落实的诗句
  • 贵州国家税务局陈开平
  • 国税系统公务员调动
  • 增值税税率有哪些规定
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设