SQL 调优最佳实践笔记

定义与重要性

  • SQL 调优:提高SQL性能,减少查询时间和资源消耗。
  • 目标:减少查询时间和扫描的数据行数。

基本原则

  1. 减少扫描行数:只扫描所需数据。
  2. 使用合适索引:确保WHERE条件命中最优索引。
  3. 合适的Join类型:根据表的大小和关联性选择。
  4. 选择合适的数据库:根据业务类型选择OLTP或OLAP。

DQL最佳实践(SELECT)

  • 避免多表JOIN,尤其是大数据量情况下。
  • 避免全表扫描,使用索引优化查询。
索引使用
  1. 全表扫描问题:无索引或索引不合适。
  2. 索引创建 :如CREATE INDEX idx_title ON books (title);
  3. 覆盖索引:包含查询所需所有列,减少回表查询。
  4. 主键点查:使用主键索引快速查询特定数据。

避免不必要的信息

  • 使用具体的列名代替SELECT *
  • 根据业务需求返回必要的列。

DML最佳实践(INSERT、UPDATE、DELETE)

  • 批量操作:使用单个SQL操作多行数据。
  • 删除数据
    • 使用WHERE条件指定删除范围。
    • 避免大批量删除,使用循环或限制条件。
    • 使用TRUNCATE代替DELETE清空表数据。

索引最佳实践

  1. 创建索引
    • 及时删除不需要的索引。
    • 考虑查询能否使用覆盖索引。
    • 选择过滤性好的列创建索引。
    • 组合索引时,将等值条件列放在前面。
  2. 使用索引
    • 确保索引在查询中被使用。
    • 遵循左前缀规则。
    • 避免使用!=NOT INLIKE '%...'等降低索引效率的条件。

总结

  • SQL调优是一个全面的优化过程,包括查询类SQL、索引优化等。
  • 针对不同的业务场景和数据库特性,采取相应的优化策略。
相关推荐
穗余15 分钟前
2026 AI x Web3 School共学营笔记-Day1
人工智能·笔记·web3
码云骑士15 分钟前
Redis 入门实战:从 NoSQL 概念到安装与基础操作详解(一)
数据库·redis·缓存
YL2004042616 分钟前
MySQL-进阶篇-锁
数据库·mysql
sheeta199816 分钟前
LeetCode 每日一题笔记 日期:2026.05.20 题目:2657. 找到前缀公共数组
笔记·算法·leetcode
爱喝水的鱼丶25 分钟前
SAP-ABAP:数据类型与数据对象(8篇) 第七篇:进阶优化篇——基于类型与对象特征的性能优化技巧
运维·数据库·学习·性能优化·sap·abap·开发交流
SelectDB技术团队29 分钟前
PB 级自动驾驶数据秒级检索:Apache Doris 统一多模态数据平台实践
数据库·人工智能·自动驾驶·apache doris·selectdb
ABAP 成33 分钟前
删除+新增原始BOM工序+订单BOM+工序笔记
笔记
XS03010639 分钟前
MyBatis基础实战笔记一
笔记·mybatis
爱编程的小新☆40 分钟前
LangGraph4j工作流框架
前端·数据库·ai·langchain·langgraph4j
Oll Correct1 小时前
实验二十五:从IPv4向IPv6过渡所使用的隧道技术
网络·笔记