关于sql优化(一)

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 关于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
相关文章
|
25天前
|
SQL 存储 关系型数据库
一文搞懂SQL优化——如何高效添加数据
**SQL优化关键点:** 1. **批量插入**提高效率,一次性建议不超过500条。 2. **手动事务**减少开销,多条插入语句用一个事务。 3. **主键顺序插入**避免页分裂,提升性能。 4. **使用`LOAD DATA INFILE`**大批量导入快速。 5. **避免主键乱序**,减少不必要的磁盘操作。 6. **选择合适主键类型**,避免UUID或长主键导致的性能问题。 7. **避免主键修改**,保持索引稳定。 这些技巧能优化数据库操作,提升系统性能。
221 4
一文搞懂SQL优化——如何高效添加数据
|
1月前
|
SQL 存储 数据库连接
日活3kw下,如何应对实际业务场景中SQL过慢的优化挑战?
在面试中,SQL调优是一个常见的问题,通过这个问题可以考察应聘者对于提升SQL性能的理解和掌握程度。通常来说,SQL调优需要按照以下步骤展开。
|
1月前
|
SQL 关系型数据库 MySQL
【MySQL 数据库】7、SQL 优化
【MySQL 数据库】7、SQL 优化
49 0
|
2月前
|
SQL 存储 数据库
面试题19: 如何优化SQL查询?
面试题19: 如何优化SQL查询?
面试题19: 如何优化SQL查询?
|
1月前
|
存储 关系型数据库 MySQL
最全MySQL面试60题(含答案):存储引擎+数据库锁+索引+SQL优化等
最全MySQL面试60题(含答案):存储引擎+数据库锁+索引+SQL优化等
174 0
|
2天前
|
SQL 分布式计算 资源调度
一文解析 ODPS SQL 任务优化方法原理
本文重点尝试从ODPS SQL的逻辑执行计划和Logview中的执行计划出发,分析日常数据研发过程中各种优化方法背后的原理,覆盖了部分调优方法的分析,从知道怎么优化,到为什么这样优化,以及还能怎样优化。
|
10天前
|
SQL 关系型数据库 数据库
【后端面经】【数据库与MySQL】SQL优化:如何发现SQL中的问题?
【4月更文挑战第12天】数据库优化涉及硬件升级、操作系统调整、服务器/引擎优化和SQL优化。SQL优化目标是减少磁盘IO和内存/CPU消耗。`EXPLAIN`命令用于检查SQL执行计划,关注`type`、`possible_keys`、`key`、`rows`和`filtered`字段。设计索引时考虑外键、频繁出现在`where`、`order by`和关联查询中的列,以及区分度高的列。大数据表改结构需谨慎,可能需要停机、低峰期变更或新建表。面试中应准备SQL优化案例,如覆盖索引、优化`order by`、`count`和索引提示。优化分页查询时避免大偏移量,可利用上一批的最大ID进行限制。
36 3
|
26天前
|
SQL 关系型数据库 MySQL
【MySQL技术之旅】(7)总结和盘点优化方案系列之常用SQL的优化
【MySQL技术之旅】(7)总结和盘点优化方案系列之常用SQL的优化
40 1
|
28天前
|
SQL 索引
SQL怎么优化
SQL怎么优化
30 2
|
1月前
|
SQL 监控 测试技术
SQL语法优化与最佳实践
【2月更文挑战第28天】本章将深入探讨SQL语法优化的重要性以及具体的优化策略和最佳实践。通过掌握和理解这些优化技巧,读者将能够编写出更高效、更稳定的SQL查询,提升数据库性能,降低系统资源消耗。