GaussDB 数据库架构师修炼(十八) SQL引擎-分布式计划

1 分布式架构

  • GaussDB基于MPP (Massively Parallel Processing) 并行架构
  • Streaming流式计算框架

2 分布式计划

  • CN轻量化(light proxy)
  • FQS( fast query shipping )
  • STREAM计划
  • XC计划

|----------|--------------------------|-----------------------|
| 计划类型 | 场景 | 原理 |
| CN轻量化 | 可以直接在一个DN执行 | 直接下发SQL语句给DN |
| FQS | 语句可以完全下推DN执 行, DN之间不需要交互 | 需要走执行器逻辑下发给DN |
| STREAM | 需要DN之间交互, CN只 汇总数据 | 在CN上生成计划,下发计划给DN执行 |
| XC | 适用于所有场景 | 部分语句下推DN执行,无法下推的在CN执行 |

3 计划生成

1)计划生成主要是查询的路径树计划树结构转换的过程, 在分布式场景下对关联****join 、聚集操作Agg有特殊的生成逻辑

2) 当join列与分布列不一致时,需要网络stream节点,可能生成的路径:

t1 HASH BY (c1), t2 HASH BY (c2)

SELECT * FROM t1 JOIN t2 ON cx=cy;

如下:每一种策略都有可以执行,根据最下层AGG过滤元组的数量有关。

4 不支持下推的

  • 1)根据函数属性判断下推

IMMUTABLE:忽略shippable属性,可以下推

STABLE:判断shippable,受限下推

VOLATILE:判断shippable,受限下推

2)不支持下推的语法

SQL子句中存在使用RETURNING

聚集函数使用ORDER BY、COUNT(DISTINCT expr) 、expr中的列不支持重分布

数组表达式

相关推荐
2301_795099741 小时前
c++怎么在Linux下通过文件描述符获取详细的Inode节点信息【底层】
jvm·数据库·python
阿正呀1 小时前
Bootstrap与Vite打包 Bootstrap项目如何使用Vite构建
jvm·数据库·python
m0_596749091 小时前
Python编写Flask接口如何防止爬虫抓取_使用User-Agent与频率限制
jvm·数据库·python
神明9311 小时前
c++如何判断一个路径是否是符号链接_is_symlink函数用法【附代码】
jvm·数据库·python
神明9311 小时前
如何实现SQL存储过程动态排序_配合参数过滤与排序逻辑
jvm·数据库·python
2401_880071401 小时前
PHP 多维数组中按唯一 ID 生成从 0 开始的连续序号
jvm·数据库·python
2401_846339561 小时前
mysql如何审计误删除数据操作_mysql binlog逆向分析追踪
jvm·数据库·python
2301_769340671 小时前
如何快速查询SQL中的重复记录:GROUP BY与COUNT统计
jvm·数据库·python
m0_741481781 小时前
SQL嵌套查询逻辑重构_将复杂业务逻辑移至应用层
jvm·数据库·python
2303_821287381 小时前
Golang log包如何打印日志_Golang日志输出教程【收藏】
jvm·数据库·python