SQL 调优最佳实践笔记

server/2024/11/13 9:53:49/

定义与重要性

  • 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、索引优化等。
  • 针对不同的业务场景和数据库特性,采取相应的优化策略。

http://www.ppmy.cn/server/102277.html

相关文章

javaweb_09:Mybatis基础操作

javaweb_09:Mybatis基础操作 一、环境准备二、删除三、插入四、更新(修改)五、查询六、实践 一、环境准备 1、准备数据库表emp -- 部门管理 create table dept(id int unsigned primary key auto_increment comment 主键ID,name varchar(10…

TreeSet的排序方式

一.TreeSet的特点: 二.TreeSet对象排序练习题: 需求:利用TreeSet存储整数并进行排序 package com.itheima.a06mySet; ​ import java.util.TreeSet; ​ public class A05_TreeSetDemo1 {public static void main(String[] args) {//1.创建T…

Eureka原理与实践:构建高效的微服务架构

Eureka原理与实践:构建高效的微服务架构 Eureka的核心原理Eureka Server:服务注册中心Eureka Client:服务提供者与服务消费者 Eureka的实践应用集成Eureka到Spring Cloud项目中创建Eureka Server创建Eureka Client(服务提供者&…

LabVIEW滚动轴承故障诊断系统

滚动轴承是多种机械设备中的关键组件,其性能直接影响整个机械系统的稳定性和安全性。由于轴承在运行过程中可能会遇到多种复杂的工作条件和环境因素影响,这就需要一种高效、准确的故障诊断方法来确保机械系统的可靠运行。利用LabVIEW开发的故障诊断系统&…

React使用useRef ts 报错

最近在写自己的React项目&#xff0c;我在使用useRef钩子函数的时候发现 TS2322: Type MutableRefObject<HTMLDivElement | undefined> is not assignable to type LegacyRef<HTMLDivElement> | undefined Type MutableRefObject<HTMLDivElement | undefined&g…

SDL库自适应窗口大小及遇到的坑

一、窗口尺寸改变大小时&#xff0c;视频卡住不动 网上介绍的方法有&#xff1a; 1&#xff1a;修改源码中的代码&#xff01; SDL_OnWindowResized中的SDL_WINDOWEVENT_SIZE_CHANGED更改为SDL_WINDOWEVENT_RESIZED 2&#xff1a;SDL_EventState(SDL_WINDOWEVENT, SDL_IGNORE…

Golang | Leetcode Golang题解之第343题整数拆分

题目&#xff1a; 题解&#xff1a; func integerBreak(n int) int {if n < 3 {return n - 1}quotient : n / 3remainder : n % 3if remainder 0 {return int(math.Pow(3, float64(quotient)))} else if remainder 1 {return int(math.Pow(3, float64(quotient - 1))) * …

C#多态_接口

接口是行为的抽象表现 关键字 interface 接口申明的规范 1.不包含成员变量 2.只包含&#xff0c;方法&#xff0c;属性&#xff0c;索引器&#xff0c;事件 3.成员不能被实现 4.成员可以不用写访问修饰符&#xff0c;不能是私有的&#xff08;不写默认是public也可以写pro…