我的编程空间,编程开发者的网络收藏夹
学习永远不晚

怎样提高mysql中or和in的效率

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

怎样提高mysql中or和in的效率

怎样提高mysql中or和in的效率,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

前言

今天遇到了一个网站卡死的问题,过了几分钟就好了,找到了一个定时脚本中有个sql,执行效率很慢,DBA建议将or改为in,效率提升了几百倍

场景描述

1.两个表关联查询
2.table1 的数据量接近100万
3.table2 的数据量接近900万
4.查询条件中的title字段没有加索引
5.原始查询语句

SELECT a.id as id FROM `table1`as a left join table2 as b on a.id=b.id WHERE b.title="衣服" or b.title="裤子" or b.title="帽子" limit 0,100

6.改造后的查询语句

SELECT a.id as id FROM `table1`as a left join table2 as b on a.id=b.id WHERE b.title IN ("衣服","裤子","帽子") limit 0,100

改造后的效率

原sql的执行时间为5s,更改之后只需要0.01s

原因

查了一下资料,在数据量过百万,并且条件没有加索引,or的查询效率远远低于in,or的效率为O(n),而in的效率为O(logn), 当n越大的时候效率相差越明显。

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

怎样提高mysql中or和in的效率

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

怎样提高bitblt函数的执行效率

要提高BitBlt函数的执行效率,可以考虑以下几个方面的优化:1. 减少函数调用次数:每次函数调用都会有一定的开销,可以将多个相邻的BitBlt操作合并为一个函数调用,减少不必要的函数调用。2. 使用更高效的图像格式:选择适合当前操作的图像
2023-08-18

Python中提高代码效率技巧是怎么样的

这篇文章将为大家详细讲解有关Python中提高代码效率技巧是怎么样的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。对象相等。您认为type(a) == type(b)和type(a) is
2023-06-17

有效提高Vista搜索效率的技巧是怎样的

本篇文章为大家展示了有效提高Vista搜索效率的技巧是怎样的,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。  技巧一:快速更新搜索结果  实际工作中,我们可能经常需要在某个固定路径下搜索不同格式的文
2023-06-14

Go语言中除法运算的效率怎么提高

本文小编为大家详细介绍“Go语言中除法运算的效率怎么提高”,内容详细,步骤清晰,细节处理妥当,希望这篇“Go语言中除法运算的效率怎么提高”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。近年来,Go语言在程序员中的人
2023-07-06

MsgPack和JSON在Redis序列化中的效率怎么样

在Redis中,MsgPack比JSON更高效。MsgPack是一种二进制数据格式,相比于JSON的文本格式,MsgPack更加紧凑和高效。这意味着在将数据序列化成MsgPack格式存储到Redis时,占用的空间会更小,同时在数据解析和操作
MsgPack和JSON在Redis序列化中的效率怎么样
2024-04-29

编程热搜

目录