怎样提高mysql中or和in的效率
发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,怎样提高mysql中or和in的效率,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。前言今天遇到了一个网站卡死的问题,过了
千家信息网最后更新 2025年01月20日怎样提高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安全错误
数据库的锁怎样保障安全
杭州信创云服务器
广东服务器电源价格怎么样
日本现存化学物质数据库
服务器 维修
网络安全与加密
数据库原理与技术课件目录
哈尔滨佳华网络技术公司
网络安全大赛中国表现
网络安全必须做以下哪几点
网络安全基金龙头
我的世界灵域服务器
网络安全国内外大的品牌
软件开发合同范本详细
南京专业软件开发销售电话
删除表的全部数据库
枣庄平台软件开发推荐
盛事通数据库指的是什么
南开金蝶软件开发怎么样
和平精英国际版哪个服务器人多
数据库对高校的重要性
张舟怡帆网络技术公司面试条件
30m服务器
数据库的分页是什么意思
东方财富跨股票引用数据库
网络安全进校园稿
软件更新服务器错误
联想服务器id用处
数据库在键码属性上建立索引
网络技术的看法
南开金蝶软件开发怎么样