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

SQL怎么优化执行效率更高?

SQL怎么优化执行效率更高?

1.SQL优化的原则是:将一次操作需要读取的BLOCK数减到最低,即在最短的时间达到最大的数据吞吐量。

调整不良SQL通常可以从以下几点切入:

检查不良的SQL,考虑其写法是否还有可优化内容

检查子查询 考虑SQL子查询是否可以用简单连接的方式进行重新书写

检查优化索引的使用

考虑数据库的优化器

2.避免出现SELECT * FROM table 语句,要明确查出的字段。

3.在一个SQL语句中,如果一个where条件过滤的数据库记录越多,定位越准确,则该where条件越应该前移。

4.查询时尽可能使用索引覆盖。即对SELECT的字段建立复合索引,这样查询时只进行索引扫描,不读取数据块。

5.在判断有无符合条件的记录时建议不要用SELECT COUNT (*)和select top 1 语句。

6.使用内层限定原则,在拼写SQL语句时,将查询条件分解、分类,并尽量在SQL语句的最里层进行限定,以减少数据的处理量。

7.应绝对避免在order by子句中使用表达式。

8.小心使用 IN 和 OR,需要注意In集合中的数据量。建议集合中的数据不超过200个。

9.<> 用 < 、 > 代替,>用>=代替, < 用< =代替,这样可以有效的利用索引。

10.在查询时尽量减少对多余数据的读取包括多余的列与多余的行。

11.对于复合索引要注意,例如在建立复合索引时列的顺序是F1,F2,F3,则在where或order by子句中这些字段出现的顺序要与建立索引时的字段顺序一致,且必须包含第一列。只能是F1或F1,F2或F1,F2,F3。否则不会用到该索引。


http://www.kler.cn/news/157628.html

相关文章:

  • 03_W5500TCP_Client
  • 视频的关键知识
  • STM32使用SIM900A、SIM800C、SIM800A完成短信发送、连接onenet上传数据、拨打电话_完整教程
  • go写文件后出现大量NUL字符问题记录
  • 常见代码优化案例记录
  • 2023.12.4 -JAVA学习第二天
  • 家用小型洗衣机哪款性价比高?内衣洗衣机品牌推荐
  • ESP32 freeRTOS笔记 参数传递、任务优先级
  • 【每日一题】从二叉搜索树到更大和树
  • 仅 CSS 阅读进度条
  • Spring Boot 之 ModelFactory
  • 【23-24 秋学期】NNDL 作业12 优化算法2D可视化
  • 【蓝桥杯软件赛 零基础备赛20周】第5周——高精度大数运算与队列
  • 基于Python的PyGame的俄罗斯方块游戏设计与实现
  • HostHunter虚拟主机发现
  • 12、pytest上下文友好的输出
  • 【重点】【滑动窗口】76.最小覆盖子串
  • YoloV5改进策略:Swift Parameter-free Attention,无参注意力机制,超分模型的完美迁移
  • VSCode Vue 开发环境配置
  • clip-path,css裁剪函数
  • C语言碎片知识
  • PTA 7-231 买文具
  • 陀螺仪LSM6DSV16X与AI集成(2)----姿态解算
  • 数据结构-栈和队列
  • 一键式紧急报警柱系统
  • 力扣labuladong一刷day27天数组去重
  • 4-Docker命令之docker run
  • 剑指 Offer(第2版)面试题 16:数值的整数次方
  • JAVA-作业7-画一个笑脸
  • 【算法】算法题-20231205