位置: 编程技术 - 正文

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

  • 免征增值税的会计处理 进项
  • 递延所得税负债是什么科目
  • 销项税大于进项税时怎么处理
  • 契税计入税金及附加吗
  • 咨询费计入什么明细科目
  • 发票代签怎么处理
  • 超过认证期限的发票未抵扣能红冲吗
  • 回购股份限售
  • 公司开办费有哪些
  • 向非关联企业捐赠现金会计分录
  • 房地产收到客户房款如何做账
  • 招待客人的场景图
  • 车间领用低值易耗品记账凭证
  • 银行利息收入可以开增值税专用发票
  • 营改增后小规模纳税人税率是多少
  • 合伙企业出资额不计入实收资本和资本公积 那放哪
  • 案例分析房租完税证明怎么入账?
  • 工会经费的缴费主体
  • 3%小规模纳税人开出的发票 农产品成本如何计算
  • 小规模收到增值税专用发票咋处理
  • 未弥补完亏损可以计提盈余公积
  • 小规模自开专票税率是1%还是3%
  • 通过拍卖取得的车牌号,过期了怎么办
  • 抵扣给供货商预缴税款
  • 餐饮行业必须要对公账户吗
  • 工程合同主要看什么
  • 电脑如何进入bios设置
  • win11不能用u盘
  • win10记事本怎么改字体颜色
  • 最小的电脑是多少寸的
  • 应酬用的香烟
  • php 访问数据库
  • 生产车间人员招聘要求
  • 劳务公司差额计税的税率
  • 销售多余材料的成本
  • 模具固定资产如何核算
  • 子公司如何向母公司申请用印
  • 开了红字发票申请还要做进项税转出吗
  • 电脑自学网
  • mongodb索引使用正则表达式
  • 帝国cms结合项多选
  • 织梦模板改成帝国模板
  • 银行手续费和利息会计分录
  • 短期借款属于经营活动还是筹资活动
  • sql server 2016使用
  • sh sqlplus
  • 股权变更后税务登记
  • 销项发票属于哪个科目
  • 简易征收的进项税额转出
  • 售后租回承租人怎么处理
  • 会计原材料的账怎么记账
  • 记账凭证填制完毕
  • 印花税怎么申报缴纳
  • 会计为什么要计提费用
  • 会计常用表格都有哪些技能
  • 财务费用怎么记账
  • mysql建索引有哪些策略和原则
  • SQL Server 作业同步 (结合备份作业)
  • sqlserver日期范围
  • ubuntuone
  • linux备份系统命令
  • 怎么在win7开始菜单添加文件夹
  • centos hosts
  • win10怎么安装java?win10系统安装java的方法
  • 安装samba服务器步骤
  • linux系统的安装配置
  • 新手学做ppt
  • cocos2dx 3.17
  • 深入解读2023年一号文件
  • MaterialCheckBox
  • 用批处理结束进程
  • dom方法总结
  • unity3d 场景
  • python中运算符/和//的区别
  • Django1.7+python 2.78+pycharm配置mysql数据库
  • 简单的比较
  • 阜阳市税务局地址
  • 国家税务总局大连电子税务局
  • 税务非正常户要提交什么资料
  • 广东省地方税务局公告2017年第6号
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设