怎样提高mysql中or和in的效率
发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,怎样提高mysql中or和in的效率,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。前言今天遇到了一个网站卡死的问题,过了
千家信息网最后更新 2025年11月07日怎样提高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越大的时候效率相差越明显。
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注行业资讯频道,感谢您对的支持。
效率
查询
数据
帽子
条件
衣服
裤子
语句
加索
帮助
改造
怎样提高
原始
清楚
两个
内容
前言
原因
场景
字段
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
有效的企业内网网络安全
山东软件开发人日单价标准
专利信息中心数据库中检索
编程软件开发就业
永久怀旧服服务器合服了吗
一年级网络安全第一课视频
以服务器数据库连接失败
我的世界国际版24小时服务器
数据库收缩
软件开发的生命周期模型中
儿童网络安全知识手抄报
江西省网络安全招聘
深圳卓远网络技术有限公司
网络安全执法十大类案例
为什么网络安全设备异常
数据库记录日志文件
海曙软件开发工程
蚌埠餐饮软件开发定制公司
荣耀全明星进哪个服务器
数据库.db 大小
暨南大学网络安全复试
ui设计需要哪些软件开发
服务器cdn加速
apex加速哪个服务器人多
英雄之路是哪个服务器
软件开发有哪些输出
php项目数据库修改吗
网络安全事务性工作
准系统服务器可以做什么用途
中美网络安全2019