SQL Optimizer的语法是什么

发布时间:2022-08-13 15:16:14 作者:iii
来源:亿速云 阅读:129

这篇文章主要介绍“SQL Optimizer的语法是什么”,在日常操作中,相信很多人在SQL Optimizer的语法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”SQL Optimizer的语法是什么”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

一、 大数据体系和SQL

1、SQL的处理流程

SQL Optimizer的语法是什么

1.1 Parser

String -> AST (Abstruct Syntax Tree):

实现:递归下降 (ClickHouse),Flex 和 Bison (PostgreSQL),JavaCC (Flink),Antlr (Presto,Spark)

1.2 Analyzer和Logical Plan

 Analyzer:

 Logical Plan:

SQL Optimizer的语法是什么

SQL Optimizer的语法是什么

SQL Optimizer的语法是什么

1.3 Physical Plan 和 Executor

 Physical Plan: 执行计划子树

 Executor

1.4 小结

二、 常见的查询优化器

1、查询优化器分类

SQL Optimizer的语法是什么

SQL Optimizer的语法是什么

2、RBO(Rule-based optimizer)

2.1 关系代数
2.2 优化原则

SQL Optimizer的语法是什么

2.3 RBO-列裁剪
2.4 RBO-谓词下推
2.5 RBO-传递闭包
2.6 RBO-Runtime Filter

对一个join如果能在查询端提早过滤不必要数据,可减少开销

2.7 小结

SQL Optimizer的语法是什么

3、CBO(Cost-based optimizer)

3.1 CBO-概念

△使用一个模型估算执行计划的代价,选择代价最小的执行计划

△算子代价:CPU,内存,磁盘IO,网络I/O等代价

统计信息+推导规则→计算算子代价→计算执行计划代价→执行计划枚举

3.2 CBO-统计信息

原始表统计信息

推导统计信息

3.2.1 CBO-统计信息的收集方式

CREATE TABLE REGION( R_ REGIONKEY INT NOT NULL, R NAME CHAR(25) NOT NULL, R_ COMMENT VARCHAR(152) ) DUPLICATE KEY(R_ REGIONKEY) DISTRIBUTED BY HASH(R_ REGIONKEY) BUCKETS 1 PROPERTIES (" sotumnselelR w");

ANALYZE TABLE table_name COMPUTE STATISICS FOR COLUMNS column-name1,column-name2....

动态采样:

SELECT count(*) FROM table_name

3.2.2 CBO-统计信息推导规则

3.3 CBO-执行计划枚举

SQL Optimizer的语法是什么

3.4 CBO-小结

4、总结

三、 社区开源实践

1、Apache Calcite概览

1.1 Calcite RBO

HepPlanner

1.2 Calcite CBO

VolcanoPlanner

1.3 小结

四、 前沿趋势

1、AI4DB

2、DB4AI

3、总结

到此,关于“SQL Optimizer的语法是什么”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

推荐阅读:
  1. SQL server 基本语法
  2. mysql Tracing the Optimizer

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

sql optimizer

上一篇:MySQL有哪些约束

下一篇:PHP网络安全之命令执行漏洞及防御的方法

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》