关于sql优化(一)

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介: 关于sql优化(一) 在开发应用过程中,对数据的处理是比较重视的过程,因此对于优化sql或者是写出更加高效并且合适的sql尤为重要,下面我将描述sql优化的方法。     当一个sql性能有问题时,我们怎么样快速定位出该sql暴露出来的问题呢?     第一、通过show status命令了解sql的执行频率。

关于sql优化(一)

在开发应用过程中,对数据的处理是比较重视的过程,因此对于优化sql或者是写出更加高效并且合适的sql尤为重要,下面我将描述sql优化的方法。

    当一个sql性能有问题时,我们怎么样快速定位出该sql暴露出来的问题呢?

    第一、通过show status命令了解sql的执行频率。

          mysql连接成功后,通过show[session/global] status命令可以获取服务器状态信息,session和global来分别显示“当前连接”的统计结果和“数据库上次启动至今”的统计结果,不写的话,默认为session级别。

    

com_xxx表示每个xxx语句的执行次数,比如一下几个操作的次数:

com_select:执行select的次数,一次查询只累加1。

com_insert:执行insert的次数,对于批量插入的insert操作,只累加一次。

com_update:执行update的次数。

com_delete:执行delete的次数。

对于Innodb存储引擎的(关于mysql存储引擎请参考这篇文章《mysql存储引擎介绍》),累加的算法略有不同。

Innodb_rows_read:select查询返回的行数。

Innodb_rows_inserted:insert操作插入的行数。

Innodb_rows_updated:update操作更新的行数。

Innodb_rows_deleted:delete操作删除的行数。

通过这些参数,可以知道该数据库是以插入、更新为主,还是查询为主,以及sql的执行大致比例。

另外,可以通过com_commit,com_rollback了解事务的提交和回滚的情况,对于回滚比较频繁的数据库,可能代码上会有问题。 

第二、通过explain分析低效率sql的执行

简单解析下列的意思:

    select_type:表示select的类型,simple(简单查询-不使用表连接或者子查询)、primary(主查询)、union(union的第二个或者后面的查询语句)、subquery(子查询中的第一个select)等。

    table:输出结果的表。

    type:表示mysql在表中找到所需行的方式,也可以叫做访问类型。

        

ALL index range ref eq_ref const,system NULL

从左至右,性能从最差到最好。

type=ALL:全表扫描,遍历全表来找到匹配的行,显而易见效率最低。

type=index:索引全扫描,遍历整个索引来查询匹配的行。

type=range:索引范围扫描,常用于<、<=、>、>=、between等操作符。

type=ref:使用非唯一索引扫描或者唯一索引的前缀扫描(类似index(n)表示前n个),返回匹配某个单独值的记录行。

type=eq_ref:使用唯一索引扫描,就是多表连接中使用primary key 或者 unique index作为关联条件。

type=const,system:单表最多有一个匹配行,查询出来非常迅速,所以这个匹配行的其他列的值可以被优化器在当前查询中当作常量来处理。

type=NULL:mysql不访问表或者索引,比如:select 1 from dual。

原文地址https://blog.csdn.net/kecong532664/article/details/79800400

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
28天前
|
SQL 缓存 Java
sql优化方法
sql优化方法
19 0
|
2月前
|
SQL 存储 关系型数据库
一文搞懂SQL优化——如何高效添加数据
**SQL优化关键点:** 1. **批量插入**提高效率,一次性建议不超过500条。 2. **手动事务**减少开销,多条插入语句用一个事务。 3. **主键顺序插入**避免页分裂,提升性能。 4. **使用`LOAD DATA INFILE`**大批量导入快速。 5. **避免主键乱序**,减少不必要的磁盘操作。 6. **选择合适主键类型**,避免UUID或长主键导致的性能问题。 7. **避免主键修改**,保持索引稳定。 这些技巧能优化数据库操作,提升系统性能。
287 4
一文搞懂SQL优化——如何高效添加数据
|
2月前
|
SQL 存储 关系型数据库
SQL优化之Explain详解(mysql)
`Explain`是MySQL中用于分析SQL查询执行计划的工具。它可以帮助我们了解MySQL如何执行SQL语句,包括如何使用索引、预计的行数以及查询的顺序。以下是`Explain`输出的关键列及其含义的简要摘要: 1. **id**:查询的序列号,表示查询中的子句层次,id越大优先级越高。 2. **select_type**:表示查询的类型,如SIMPLE(简单查询)、PRIMARY(主查询,多表查询中的第一个查询)、SUBQUERY(子查询)、DERIVED(派生表)或UNION(UNION操作的查询部分)。 3. **table**:查询涉及的表名,如果是子查询,可能显示为衍生表
33 0
|
1月前
|
SQL 关系型数据库 MySQL
项目中遇到一张900w的数据表把原先要花费17s执行的SQL优化到300ms经验加100哈哈哈
项目中遇到一张900w的数据表把原先要花费17s执行的SQL优化到300ms经验加100哈哈哈
25 1
|
5天前
|
SQL 存储 关系型数据库
【MySQL系列笔记】SQL优化
SQL优化是通过调整数据库查询、索引、表结构和配置参数等方式,提高SQL查询性能和效率的过程。它旨在减少查询执行时间、减少系统资源消耗,从而提升数据库系统整体性能。优化方法包括索引优化、查询重写、表分区、适当选择和调整数据库引擎等。
27 3
|
7天前
|
存储 SQL 缓存
30个业务场景的SQL优化
这些优化策略和示例可以帮助改善 `SQL` 查询的性能和效率。在实践中,需要综合考虑数据库设计、`SQL` 编写、服务器配置等多方面因素,选择合适的优化方法,并进行充分的测试和验证。以上 30 个经验是 V 哥在实际经验中总结的内容,当然,业务场景不同,具体的优化策略也会不同,按实际情况处理,这不就是程序员要做的事情么。
|
7天前
|
SQL 存储 算法
clickhouse SQL优化
clickhouse 是 OLAP 数据库,但其具有独特的索引设计,所以如果拿 MySQL 或者其他 RDB 的优化经验来优化 clickhouse 可能得不到很好的效果,所以特此单独整理一篇文档,用于有 SQL 优化需求的同学,本人接触 clickhouse 时间也不长,难免有不足的地方,如果大家发现错误,还请不吝指正。
|
10天前
|
SQL 关系型数据库 MySQL
【MySQL】SQL优化
【MySQL】SQL优化
|
12天前
|
SQL 存储 关系型数据库
MySQL SQL优化
MySQL SQL优化
14 0
|
14天前
|
SQL 分布式计算 资源调度
一文解析 ODPS SQL 任务优化方法原理
本文重点尝试从ODPS SQL的逻辑执行计划和Logview中的执行计划出发,分析日常数据研发过程中各种优化方法背后的原理,覆盖了部分调优方法的分析,从知道怎么优化,到为什么这样优化,以及还能怎样优化。
103478 1