当前位置: 首页 > news >正文

一般在写SQL时需要注意哪些问题,可以提高查询的效率?

很多人写SQL按照自己喜好,没有规则意识,这对于自主查询影响不大,你爱怎么搞就怎么搞,一旦涉及到提交任务或团队共享,就不能乱写了,会浪费资源影响到开发效率,严重的甚至会服务器瘫痪。

提几个关于SQL优化的小建议,都是细节的问题。

1、尽量不要使用select * from ...,要在后面加limit限制行数,并且选择要查询的字段

2、多使用Exists()和Join(),而非where in子查询

3、为表创建索引列,查询速度会更快

索引有很多好处,会降低数据库的IO成本,会降低分组消耗的成本,降低数据排序成本等等

看到一个索引的解释比较形象

索引的目的在于提高查询效率,可以类比字典,如果要查“mysql”这个单词,我们肯定需要定位到m字母,然后从下往下找到y字母,再找到剩下的sql。如果没有索引,那么你可能需要把所有单词看一遍才能找到你想要的,如果我想找到m开头的单词呢?或者ze开头的单词呢?是不是觉得如果没有索引,这个事情根本无法完成?

4、筛选字段,尽量避免使用or,可以用

5、尽量不要join很多表,小心会过载,执行效率也会很低,可以将长查询拆分成多个查询,最后再连接

6、尽量不要使用select distinct,这个过程需要处理大量数据,速度会比较慢

7、如果是在公司服务器执行查询,尽量选择非高峰期查询

8、查询语言要写注释,让同事能看懂,同时也是让以后的自己能看懂

9、尽量使用UNION ALL,而不是UNION,因为后者是取交集,速度更慢

10、对于频繁使用的数据和更复杂的查询,要使用存储过程

11、建表时选择适当的数据类型,不然会造成资源浪费

12、表越大查询速度越慢,所以在连接聚合操作时,尽可能将表精简到最小

13、尽量不要使用 %前缀进行模糊前缀查询

14、在取出字段上可以使用相关函数,但是在 Where 条件中的过滤条件字段上避免使用任何函数,包括数据类型转换函数,以避免索引失效。或者可以考虑使用表达式索引功能

15、SQL代码中应用到的所有SQL关键字、保留字都需使用全大写或小写


http://www.mrgr.cn/news/47410.html

相关文章:

  • hutool-http实现离线爬虫
  • 2 XDMA IP中断
  • 服务器数据恢复—raid5故障导致上层ORACLE无法启动的数据恢复案例
  • 解决idea中无法拖动tab标签页的问题
  • 【数据分析(一)】初探 Numpy
  • priority_queue优先队列
  • 手机通过carlink投屏到车机,播放QQ音乐卡顿问题分析
  • 网站服务器监控:Apache指标解读
  • 什么是UEBA?派拉软件的“暗能力”!
  • 流域生态系统服务评价、水文水生态分析、碳收支、气候变化影响、制图等领域中的应用
  • 还在为Python“运算符”中遇到的BUG而发愁吗?,变量相关的问题和解决办法看这篇文章就够了!
  • python+request+unittest+ddt自动化框架
  • TAGE-SC分支预测器
  • COMPILER_ABSTRACTION头文件的关键字
  • 东方博宜 1176. 素数问题
  • LangChain
  • 电商序列推荐算法
  • 基于springboot的大学生体质测试管理系统(含源码+sql+视频导入教程)
  • 【云原生】利用 docker api 管理容器
  • HWS赛题 入门 MIPS Pwn-Mplogin(MIPS_shellcode)
  • 二分法(Bisection Method)求解方程 f(x)=0近似解(MATLAB)
  • 基于java的零食销售系统(源码+定制+开发)
  • 前端_001_html扫盲
  • 逼近理论及应用精解【14】
  • HT8312 内置高效率自适应电荷泵升压,防削顶失真功能,DIAB切换的5.2W单声道高保真音频功率放大器
  • Vue3 ECharts看板