PolarDB-X 1.0-用户指南—SQL调优指南—SQL调优基础概念

本文涉及的产品
云原生数据库 PolarDB 分布式版,标准版 2核8GB
简介: 在使用PolarDB-X的过程中,可能出现性能不符合预期的慢SQL。SQL调优的过程,就是通过分析SQL的执行计划、各阶段运行时长等信息,找出导致SQL执行慢的原因,继而解决问题。

在使用PolarDB-X的过程中,可能出现性能不符合预期的慢SQL。SQL调优的过程,就是通过分析SQL的执行计划、各阶段运行时长等信息,找出导致SQL执行慢的原因,继而解决问题。

PolarDB-X架构

PolarDB-X是一个支持计算存储分离架构的数据库产品。当一条查询SQL(称为逻辑SQL)发往PolarDB-X节点时,PolarDB-X会将其分成可下推的、和不可下推的两部分,可下推的部分也被称为物理SQL。

custom import 1.png

原则上,PolarDB-X会:

  • 尽可能将用户SQL下推到MySQL上执行。
  • 对于无法下推的部分算子,选择最优的方式来执行。

下推和执行计划

EXPLAIN指令将会打印SQL的执行计划。它的用法非常简单:只要在SQL最前面加上EXPLAIN即可。下面通过几个例子来展示PolarDB-X的执行方式。

示例一:


> explain select c_custkey, c_name, c_address from customer where c_custkey = 42;
LogicalView(tables="customer_2", sql="SELECT `c_custkey`, `c_name`, `c_address` FROM `customer` AS `customer` WHERE (`c_custkey` = ?)")

对于带有主键条件的查询来说,PolarDB-X只要将SQL直接下发到主键对应的分片上即可。因此,执行计划中只有一个LogicalView算子,下发的物理SQL基本和逻辑SQL是一样的。

LogicalView算子代表下推到MySQL执行的查询,请参见执行计划和基本算子

示例二:


> explain select c_nationkey, count(*) from customer group by c_nationkey;
HashAgg(group="c_nationkey", count(*)="SUM(count(*))")
  Gather(concurrent=true)
    LogicalView(tables="customer_[0-7]", shardCount=8, sql="SELECT `c_nationkey`, COUNT(*) AS `count(*)` FROM `customer` AS `customer` GROUP BY `c_nationkey`")

上述查询会统计:各个国家的客户数量分别有多少?考虑到分库分表,可以将它分成两个阶段来进行:

  1. 在各个分表上进行COUNT(*)统计(这一步可被下推到MySQL上执行)。
  2. 将结果汇总,将COUNT(*)的结果执行SUM(),得到最终的结果(这一步需要PolarDB-X节点来完成)。

从执行计划上,也可以看出这一点。其中:

  • LogicalView表示下发到各个分片的SQL按nation分组进行 COUNT(*)统计。
  • Gather算子表示收集各个分片的结果。
  • HashAgg是聚合(Aggregate)的一种实现方式,以c_nationkey作为分组键将 COUNT(*)的结果求SUM()

更多的例子,详情请参见执行计划和基本算子

相关实践学习
快速体验PolarDB开源数据库
本实验环境已内置PostgreSQL数据库以及PolarDB开源数据库:PolarDB PostgreSQL版和PolarDB分布式版,支持一键拉起使用,方便各位开发者学习使用。
相关文章
|
8月前
|
SQL 缓存 监控
drds性能监控与调优
drds性能监控与调优
258 2
|
SQL 监控 数据库
PolarDB-X 2.0,同一条sql,有时执行200ms,有时8000毫秒,是什么原因,频率很高.?
PolarDB-X 2.0,同一条sql,有时执行200ms,有时8000毫秒,是什么原因,频率很高.?
108 1
|
6月前
|
关系型数据库 分布式数据库 数据库
PolarDB产品使用问题之将RDS切换到PolarDB-X 2.0时,代码层的SQL该如何改动
PolarDB产品使用合集涵盖了从创建与管理、数据管理、性能优化与诊断、安全与合规到生态与集成、运维与支持等全方位的功能和服务,旨在帮助企业轻松构建高可用、高性能且易于管理的数据库环境,满足不同业务场景的需求。用户可以通过阿里云控制台、API、SDK等方式便捷地使用这些功能,实现数据库的高效运维与持续优化。
|
SQL 关系型数据库 分布式数据库
drds和polardb的sql语句分别有哪些
drds和polardb的sql语句分别有哪些
164 1
|
8月前
|
SQL 存储 缓存
PolarDB-X SQL限流
本文首先介绍了SQL限流的使用场景,它可通过限制边缘业务查询,留出资源来为核心业务保驾护航。接着是功能简介,PolarDB-X结合自身云原生分布式的特点,提供了具有简洁易用的交互接口、多样的限流策略、平均复杂度O(1)、节点级限流实例级监控的SQL限流能力。
150 1
PolarDB-X SQL限流
|
8月前
|
SQL Java 调度
PolarDB-X SQL限流 (二)
当前PolarDB-X正在全面对接阿里云 ''数据库自治服务 DAS",PolarDB-X限流能力将会以白屏化的方式提供给用户,经一步提升用户体验,降低使用门槛。
145 0
PolarDB-X SQL限流 (二)
|
8月前
|
SQL 弹性计算 测试技术
实践教程之如何在PolarDB-X中优化慢SQL
PolarDB-X 为了方便用户体验,提供了免费的实验环境,您可以在实验环境里体验 PolarDB-X 的安装部署和各种内核特性。除了免费的实验,PolarDB-X 也提供免费的视频课程,手把手教你玩转 PolarDB-X 分布式数据库。本期实验将指导您使用对 PolarDB-X 进行慢SQL优化。...
实践教程之如何在PolarDB-X中优化慢SQL
|
8月前
|
SQL 运维 数据库
PolarDB-X 限流慢SQL的方法
如果用户发现活跃连接数、cpu 使用率等指标处于高位, 同时慢SQL日志中发现大量记录, 分析得出是大量慢 SQL占用了数据库资源,而且这些慢SQL已经影响到整体核心业务的稳定运行,此时我们需要对其进行限流。
162 0
PolarDB-X 限流慢SQL的方法
|
4月前
|
关系型数据库 MySQL 网络安全
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
|
6月前
|
SQL 存储 监控
SQL Server的并行实施如何优化?
【7月更文挑战第23天】SQL Server的并行实施如何优化?
144 13

相关产品

  • 云原生分布式数据库 PolarDB-X
  • 下一篇
    开通oss服务