关于sql优化(一)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 关于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

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
SQL 存储 关系型数据库
如何巧用索引优化SQL语句性能?
本文从索引角度探讨了如何优化MySQL中的SQL语句性能。首先介绍了如何通过查看执行时间和执行计划定位慢SQL,并详细解析了EXPLAIN命令的各个字段含义。接着讲解了索引优化的关键点,包括聚簇索引、索引覆盖、联合索引及最左前缀原则等。最后,通过具体示例展示了索引如何提升查询速度,并提供了三层B+树的存储容量计算方法。通过这些技巧,可以帮助开发者有效提升数据库查询效率。
172 2
|
28天前
|
SQL 缓存 监控
大厂面试高频:4 大性能优化策略(数据库、SQL、JVM等)
本文详细解析了数据库、缓存、异步处理和Web性能优化四大策略,系统性能优化必知必备,大厂面试高频。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
大厂面试高频:4 大性能优化策略(数据库、SQL、JVM等)
|
14天前
|
SQL 缓存 数据库
SQL慢查询优化策略
在数据库管理和应用开发中,SQL查询的性能优化至关重要。慢查询优化不仅可以提高应用的响应速度,还能降低服务器负载,提升用户体验。本文将详细介绍针对SQL慢查询的优化策略。
|
14天前
|
SQL 存储 BI
gbase 8a 数据库 SQL合并类优化——不同数据统计周期合并为一条SQL语句
gbase 8a 数据库 SQL合并类优化——不同数据统计周期合并为一条SQL语句
|
14天前
|
SQL 数据库
gbase 8a 数据库 SQL优化案例-关联顺序优化
gbase 8a 数据库 SQL优化案例-关联顺序优化
|
21天前
|
SQL 数据库 UED
SQL性能提升秘籍:5步优化法与10个实战案例
在数据库管理和应用开发中,SQL查询的性能优化至关重要。高效的SQL查询不仅可以提高应用的响应速度,还能降低服务器负载,提升用户体验。本文将分享SQL优化的五大步骤和十个实战案例,帮助构建高效、稳定的数据库应用。
37 3
|
1月前
|
SQL 存储 缓存
如何优化SQL查询性能?
【10月更文挑战第28天】如何优化SQL查询性能?
100 10
|
1月前
|
SQL 存储 缓存
SQL Server 数据太多如何优化
11种优化方案供你参考,优化 SQL Server 数据库性能得从多个方面着手,包括硬件配置、数据库结构、查询优化、索引管理、分区分表、并行处理等。通过合理的索引、查询优化、数据分区等技术,可以在数据量增大时保持较好的性能。同时,定期进行数据库维护和清理,保证数据库高效运行。
|
21天前
|
SQL 缓存 监控
SQL性能提升指南:五大优化策略与十个实战案例
在数据库性能优化的世界里,SQL优化是提升查询效率的关键。一个高效的SQL查询可以显著减少数据库的负载,提高应用响应速度,甚至影响整个系统的稳定性和扩展性。本文将介绍SQL优化的五大步骤,并结合十个实战案例,为你提供一份详尽的性能提升指南。
42 0
|
2月前
|
SQL 资源调度 分布式计算
如何让SQL跑快一点?(优化指南)
这篇文章主要探讨了如何在阿里云MaxCompute(原ODPS)平台上对SQL任务进行优化,特别是针对大数据处理和分析场景下的性能优化。

热门文章

最新文章