如何进行sql优化?

在日常工作中都避免不了要和各种SQL语句打交道,无论是开发还是后期维护,一条执行效率高的SQL语句都会对系统性能产生巨大影响。那么,如何进行有效的SQL优化呢?下面将为大家深入浅出地讲解SQL优化的各个方面:

1、了解数据表和查询的基础

在进行SQL优化之前,你得先了解你的数据表以及你的查询。掌握表中数据的类型、分布和大小。这个过程包括:

  • 分析表结构:查看表的索引、字段类型等,确保其符合最佳实践。
  • 理解数据特性:了解数据的分布特性,哪些字段经常被查询,哪些字段数据量较大等。

假设我现在的表结构如下

CREATE TABLE users (
    id INT AUTO_INCREMENT PRIMARY KEY,
    username VARCHAR(50) NOT NULL,
    email VARCHAR(100),
    created_at DATETIME,
    last_login DATETIME
);

2、使用EXPLAIN分析执行计划

MySQL的EXPLAIN命令是优化查询的重要工具。它可以显示MySQL如何执行SQL查询,包括它是如何使用索引的,以及它是如何join表的。

explain  select * from users where username = 'mntalk';

通过分析EXPLAIN的结果,可以了解SQL执行的瓶颈在哪里,是否选择了合适的索引。

&nbsp

3、优化查询语句

**避免SELECT ***

使用SELECT *会返回表中的所有列,这通常比需要的要多。你应始终只查询需要的列。

-- 不推荐
SELECT * FROM users WHERE username = 'mntalk';

-- 推荐
SELECT username, email FROM users WHERE username = 'mntalk';

使用索引

确保对经常查询的列创建索引。但请注意,不是每个列都应该建立索引,因为索引本身也有维护成本。

使用主键索引与不使用索引查询对比
&nbsp

-- 创建索引
CREATE INDEX idx_username ON users(username);
CREATE INDEX idx_email ON users(email);

-- 使用索引的查询
SELECT username, email FROM users WHERE username = 'mntalk';

在username和email上创建索引后,查询
使用索引前:
&nbsp

使用索索引之后
&nbsp

避免在WHERE子句中使用函数或者计算

当你在WHERE子句中使用函数或者其他计算时,MySQL通常不能使用索引。

-- 不推荐
SELECT username, email FROM users WHERE MONTH(last_login) = MONTH(CURRENT_DATE()) AND YEAR(last_login) = YEAR(CURRENT_DATE());

-- 推荐
SELECT username, email FROM users WHERE last_login >= DATE_SUB(CURRENT_DATE(), INTERVAL 1 MONTH);

4、优化表结构

使用合适的数据类型

选择最合理的数据类型可以节省空间,并提高查询效率。

-- 不推荐
ALTER TABLE users MODIFY username VARCHAR(255);

-- 推荐
ALTER TABLE users MODIFY username VARCHAR(50);

规范化与反规范化

规范化可以减少数据冗余,但是可能会增加查询的复杂度。反规范化可能会增加数据冗余,但是可以简化查询。

5、查询缓存

确保合理使用查询缓存,虽然在MySQL 8.0中已经移除了查询缓存的功能,但在之前版本中,它可以通过缓存查询结果来减少服务器的负载。

6、使用批量操作

当你需要插入大量数据时,尽量使用批量操作而不是单条插入。

-- 不推荐
INSERT INTO users (username, email) VALUES ('john_doe', 'john@example.com');
INSERT INTO users (username, email) VALUES ('jane_doe', 'jane@example.com');

-- 推荐
INSERT INTO users (username, email) VALUES ('john_doe', 'john@example.com'), ('jane_doe', 'jane@example.com');

7、避免大事务操作

大事务会占用更多的锁资源,也会导致锁等待的时间增加。

8、分析和优化JOIN

使用JOIN时,应当注意顺序和条件。小表驱动大表通常会有更好的性能。

9、归档旧数据

对于历史数据,定期归档可以帮助维护表的大小,提高查询效率。

10、监控和日志

监控数据库的性能,记录慢查询日志,这有助于发现潜在的性能问题。

通过上面的介绍,我们可以明白,SQL优化是一个涉及多个层面的过程,需要我们不断学习和实践。每一条建议都可能对你的系统产生重大影响,所以建议大家在更改之前,都要进行充分的测试。

最后说一句(求关注,求赞,别白嫖我)

最近无意间获得一份阿里大佬写的刷题笔记和面经,一下子打通了我的任督二脉,进大厂原来没那么难。

这是大佬写的, 7701页的阿里大佬写的刷题笔记,让我offer拿到手软

求一键三连:点赞、分享、收藏

点赞对我真的非常重要!在线求赞,加个关注我会非常感激!@小郑说编程

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/300639.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

WorkPlus AI助理为企业提供智能客服的机器人解决方案

在数字化时代,企业面临着客户服务的重要挑战。AI客服机器人成为了提升客户体验和提高工作效率的关键工具。作为一款优秀的AI助理,WorkPlus AI助理以其智能化的特点和卓越的功能,为企业提供了全新的客服机器人解决方案。 为什么选择WorkPlus A…

格密码基础:光滑参数

目录 一. 铺垫高斯函数 二. 光滑参数图形理解 三. 光滑参数与格基本区 3.1 高斯与均匀分布的统计距离 3.2 光滑参数理解 四. 光滑参数与最短向量 五. 光滑参数与连续最小值 六. 光滑参数与对偶格的上界 七. 光滑参数与格的上界 八. 小结 一. 铺垫高斯函数 定义高斯密…

MIT 6.s081 实验解析——labs2

系列文章目录 MIT 6.s081 实验解析——labs1 MIT 6.s081 实验解析——labs2 文章目录 系列文章目录测试判断流程System call tracingsysinfo![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/ab9ca34f1fc64b6aa1df74613dc1a397.png) 测试判断流程 完成代码后将.c文…

K8S Prometheus-rocketmq-exporter配置

下载rocketmq-exporter 通过Docker仓库下载 docker pull sawyerlan/rocketmq-exporter:latest 然后打标签,推送到自己的仓库 也可通过代码自己build镜像 git clone GitHub - apache/rocketmq-exporter: Apache RocketMQ Prometheus Exporter 然后打标签&#x…

iPhone 恢复出厂设置后如何恢复数据

如果您在 iPhone 上执行了恢复出厂设置,您会发现所有旧数据都被清除了。这对于清理混乱和提高设备性能非常有用,但如果您忘记保存重要文件,那就是坏消息了。 恢复出厂设置后可以恢复数据吗?是的!幸运的是,…

React Portals

简介 React Portal 可以将组件渲染到dom树的不同位置,同时可以渲染到任意父级元素,可以实现漂浮层功能。 使用样例 本篇文章通过React Portals实现对话框,下面将会给出具体实现。 protal组件 Portal.jsx import {useState} from "re…

Java环境准备:JDK与IDEA

新手小白学Java–环境准备篇 文章目录 新手小白学Java--环境准备篇第1节 JDK的下载与安装第2节 IDEA的下载与安装第3节 使用IDEA创建第一个Java项目第4节 使用小技巧查看电脑的操作系统版本显示出文件的后缀名IDEA 修改字体大小IDEA 修改显示主题色IDEA 修改单行注释的颜色IDEA…

Mysql SQL审核平台Yearning本地部署

文章目录 前言1. Linux 部署Yearning2. 本地访问Yearning3. Linux 安装cpolar4. 配置Yearning公网访问地址5. 公网远程访问Yearning管理界面6. 固定Yearning公网地址 前言 Yearning 简单, 高效的MYSQL 审计平台 一款MYSQL SQL语句/查询审计工具,为DBA与开发人员使用…

Postman实现压力测试

从事软件开发对于压力测试并不陌生,常见的一些压测软件有Apache JMeter LoadRunner Gatling Tsung 等,这些都是一些比较专业的测试软件,对于我的工作来说一般情况下用不到这么专业的测试,有时候需要对一些接口进行压力测试又不想再安装新软件,那么可以使用Postman来实现对…

MyBatis入门源码一:配置解析

一、SqlSessionFactory 的构建:SqlSessionFactoryBuilder#build(…) 看一下我们mybatis-config.xml 配置的内容: parser.parse(): 解析配置文件 解析的内容很多,重点看解析数据源、解析mapper文件 build: 创建DefaultSqlSessi…

用队列实现栈oj题——225

. 个人主页:晓风飞 专栏:LeetCode刷题|数据结构|Linux 路漫漫其修远兮,吾将上下而求索 文章目录 题目要求:实现 MyStack 类:注意:示例:解释:提示: 解题核心数据结构的定义…

Redis概览

Redis存储是Key-Value结构的数据,其中Key是字符串类型,Value有5种常见的数据类型 字符串 String 哈希 hash 列表 list 集合 set 有序集合 sorted set / zset 各种数据类型的特性 字符串操作命令 : ● SET ke…

Go-gin-example 添加注释 第一部分 新建项目及api编写

文章目录 go-gin-example环境准备初始化 Go Modules基础使用 gin 安装测试gin是否引入 gin搭建Blog APIsgo-ini简述配置文件 阶段目标 编写简单API错误码包 完成一个demo初始化项目初始化项目数据库编写项目配置包拉取go-ini配置包在conf目录下新建app.ini文件,写入…

数据结构排序(一.基本概念、插入排序和希尔排序实现)

前段时间也是结束了二叉树的知识梳理(大家想必满脑子都是递归了):二叉树链式结构的实现(二叉树的遍历以及各种常用功能函数的实现) 今天也要迈向全新的篇章了——排序。这次就先大概讲解一下排序,然后插入排序和希尔排序的介绍和实…

R304S 指纹识别模块功能实现示例

1 基本通信流程 1.1 UART 命令包的处理过程 1.2 UART 数据包的发送过程 UART 传输数据包前,首先要接收到传输数据包的指令包,做好传输准备后发送成功应答包,最后才开始传输数据包。数据包主要包括:包头、设备地址、包标识、包长…

Spring IOC的四种手动注入方法

手动注入 1.Set方法注入-五种类型的注入1.1 业务对象JavaBean第一步:创建dao包下的UserDao类第二步:属性字段提供set⽅法第三步:配置⽂件的bean标签设置property标签第四步:测试 1.2 常用对象String(日期类型&#xff…

【AI视野·今日CV 计算机视觉论文速览 第282期】Wed, 3 Jan 2024

AI视野今日CS.CV 计算机视觉论文速览 Wed, 3 Jan 2024 Totally 70 papers 👉上期速览✈更多精彩请移步主页 Daily Computer Vision Papers Street Gaussians for Modeling Dynamic Urban Scenes Authors Yunzhi Yan, Haotong Lin, Chenxu Zhou, Weijie Wang, Haiya…

togaf 9.2中文版

尊敬的读者朋友们,本专栏为togaf 9.2 的个人学习笔记,我会尽量将信息完整地传递给大家,以便更多对 togaf 感兴趣的朋友不用花费巨资去购买相关资料。本文档不需要读者具备企业架构的预备知识。 专栏受众:企业架构师、业务架构师、…

Android WiFi 连接

Android WiFi 连接 1、设置中WiFi显示2、WiFi 连接流程2.1 获取PrimaryClientModeManager2.2 ClientModeImpl状态机ConnectableState2.3 ISupplicantStaNetworkCallback 回调监听 3、 简要时序图4、原生低层驱动5、关键日志 1、设置中WiFi显示 Android WiFi基础概览 packages/a…

阿里云服务器可用区是什么?

阿里云服务器地域和可用区怎么选择?地域是指云服务器所在物理数据中心的位置,地域选择就近选择,访客距离地域所在城市越近网络延迟越低,速度就越快;可用区是指同一个地域下,网络和电力相互独立的区域&#…