怎么样优化数据库查询语句?
架构师大咖
架构师大咖,打造有价值的架构师交流平台。分享架构师干货、教程、课程、资讯。架构师大咖,每日推送。
0篇原创内容
Official Account
算法专栏
算法专栏,每日推送。算法是程序员内功,分享算法知识、文章、工具、算法题、教程等
0篇原创内容
Official Account
来源丨java学习
1、对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引。
2、应尽量避免在 where 子句中对字段进行 null 值判断,否则将 导致引擎放弃使用索引而进行全表扫描
3、应尽量避免在 where 子句中使用!=或<>操作符,否则引擎将 放弃使用索引而进行全表扫描。
4、应尽量避免在 where 子句中使用 or 来连接条件,否则将导致 引擎放弃使用索引而进行全表扫描
5、in 和 not in 也要慎用,否则会导致全表扫描
6、索引并不是越多越好,索引固然可 以提高相应的 select 的效 率,但同时也降低了 insert 及 update 的效率,因为 insert 或 update 时有可能会重建索引,所以怎样建索引需要慎重考虑,视 具体情况而定。一个表的索引数最好不要超过6个,若太多则应考虑 一些不常使用到的列上建的索引是否有必要
7、查询结果不要用*来查询所有字段,要明确指明结果字段
8、根据查询条件,建立索引,如果查询条件不止一个时,使用组合 索引
9、在查询条件表达式的左侧尽量不要使用函数,否则索引失效
10、如果有 like 话,尽量避免%xxx%两侧都有%的条件,单侧% 可以使用索引,多侧不可以
11、建立索引时字段不能有 null 值
-End-
最近有一些小伙伴,让我帮忙找一些 面试题 资料,于是我翻遍了收藏的 5T 资料后,汇总整理出来,可以说是程序员面试必备!所有资料都整理到网盘了,欢迎下载!
程序员直聘
程序员直聘,一个程序员找工作平台。
0篇原创内容
Official Account
面试题
】即可获取
在看点这里好文分享给更多人↓↓