索引字段上不要使用不等,索引字段上使用(!= 或者 < >)判断时,会导致索引失效而转向全表扫描 。
应尽量避免在 where 子句中使用 or 来连接条件,否则将导致引擎放弃使用索引而进行全表扫描 。
例如: select * from t where num=10 or num=20
我们可以这样查询:select * from t where num=10 union all select * from t where num=20
应尽量避免在 where 子句中对字段进行表达式操作,这将导致引擎放弃使用索引而进行全表扫描 。
例如:select * from t where num/2=100
我们应该改为: select * from t where num=100*2
应尽量避免在where子句中对字段进行函数操作,这将导致引擎放弃使用索引而进行全表扫描 。
例如:select * from t where substring(name,1,3)='abc' -- name以abc开头的id
我们应该改为: select * from t where name like 'abc%'
不要在 where 子句中的“=”左边进行函数、算术运算或其他表达式运算,否则系统将可能无法正确使用索引 。
很多时候用 exists 代替 in 是一个好的选择 。
例如:select num from a where num in(select num from b)
我们应该这样替换:select num from a where exists(select 1 from b where num=a.num)
总结本文作为大数据开发指南MySQL的最后一篇简洁明练的讲述了一些SQL性能优化的技巧,希望大家能够跟着老刘的文章,好好捋捋思路,争取能够用自己的话把这些知识点讲述出来!
尽管当前水平可能不及各位大佬,但老刘会努力变得更加优秀,让各位小伙伴自学从此不求人!
推荐阅读
-
IT之家@iPhone X 虚拟机成功运行 Win10 系统,苹果
-
微信群矩阵精准引流技巧,你掌握了还缺粉丝吗?网络推广
-
范子铭|十冠还不满足!曝广东运作李慕豪范子铭加盟 若成功恐成CBA巨无霸
-
科技互联网界|李诞王祖蓝在雪梨直播间热舞PK,网友吐槽反差太大
-
#莎拉杰西卡帕克#疫情扑倒《欲望都市》女主,穿休闲装配高跟鞋送货,强撑自家品牌
-
北京野生动物园|对偷天鹅蛋的游客,不应止于气愤与遗憾
-
-
-
超级替补|“三线大爆发”!鲁能U23超巨彻底踢疯了:解单刀+轰贴地斩+造点
-
socket是什么意思(socket网络连接异常是什么意思)
-
-
xubin|LPL“假赛事件”真相大白!女警五次平A不暴击,其概率只有0.097%
-
空调开着开着就停了是怎么回事显示e1 空调开着开着就停了是怎么回事
-
啥才是这个高速发展的新经济信息化时代人的核心竞争力
-
「现状」中国人在海外建立的首个共和国,面积是台湾的20倍,如今现状怎样
-
『七彩云电商』瞬间变成“木乃伊”,惊魂瞬间!粗心大意印纺织工人被卷入机器
-
热剧天天乐|二战坦克集群重现!解放军运20会参加吗?,俄罗斯红场阅兵在即
-
-
浣熊君主播|梦泪积攒了第一波人气一诺等人争气,AG包揽KPL全部十周人气战队
-