Skip to Content
For Enterprise
For Government
For Higher Ed
For Individuals
For Marketing
For Enterprise
For Government
For Higher Ed
For Individuals
For Marketing
Explore Skills
Cloud Computing
Microsoft Azure
Amazon Web Services (AWS)
Google Cloud
Cloud Migration
Cloud Deployment
Cloud Platforms
Data Engineering
Data Warehouse
SQL
Apache Spark
Microsoft SQL Server
MySQL
Kafka
Data Lake
Streaming & Messaging
NoSQL Databases
Relational Databases
Data Science
Pandas
R
MATLAB
SAS
D3
Power BI
Tableau
Statistics
Exploratory Data Analysis
Data Visualization
AI & ML
Generative AI
Machine Learning
Artificial Intelligence (AI)
Deep Learning
Reinforcement Learning
Natural Language Processing
TensorFlow
Scikit-Learn
Hyperparameter Tuning
MLOps
Programming Languages
Java
JavaScript
Spring
Python
Go
C#
C++
C
Swift
Rust
Functional Programming
Software Architecture
Object-Oriented
Distributed Systems
Domain-Driven Design
Architectural Patterns
IT/Ops
Kubernetes
Docker
GitHub
Terraform
Continuous Delivery
Continuous Integration
Database Administration
Computer Networking
Operating Systems
IT Certifications
Security
Network Security
Application Security
Incident Response
Zero Trust Model
Disaster Recovery
Penetration Testing / Ethical Hacking
Governance
Malware
Security Architecture
Security Engineering
Security Certifications
Design
Web Design
Graphic Design
Interaction Design
Film & Video
User Experience (UX)
Design Process
Design Tools
Business
Agile
Project Management
Product Management
Marketing
Human Resources
Finance
Team Management
Business Strategy
Digital Transformation
Organizational Leadership
Soft Skills
Professional Communication
Emotional Intelligence
Presentation Skills
Innovation
Critical Thinking
Public Speaking
Collaboration
Personal Productivity
Confidence / Motivation
Features
All features
Verifiable skills
AI Academy
Courses
Certifications
Interactive learning
Live events
Superstreams
Answers
Insights reporting
Radar Blog
Buy Courses
Plans
Sign In
Try Now
O'Reilly Platform
book
Presto实战
by
Matt Fuller
,
Manfred Moser
,
Martin Traverso
March 2021
Intermediate to advanced
265 pages
6h 50m
Chinese
Posts & Telecom Press
Content preview from
Presto实战
60
|
第
4
章
时,查询执行期间只会读取匹配的分区。此外,由于
Hive
中每个分区单独保存表统计信
息,因此
CBO
只使用相关分区的统计信息,从而更加精确。
当然,任何连接器都可以为过滤后的关系表提供这类改进后的统计信息,但这里仅参考
Hive
连接器提供这类统计信息的方式。
4.11.6
Join
枚举
至此,我们讨论了
CBO
如何使用数据统计信息生成执行查询的最优计划。尤其是,它会
选择最优
Join
顺序,该
Join
顺序会显著地影响查询性能,原因如下所示。
Hash Join
的实现
Hash
Join
的实现是非对称的
,非常重要的是仔细选择哪一个输入用于构建侧,哪一个
用于探测侧。
分布式
Join
的类型
非常重要的是仔细选择,
Join
的输入数据是广播的还是重分布的。
4.11.7
广播
Join
和分布式
Join
在
4.11.6
节中,你了解了
Hash
Join
的实现以及选择构建侧和探测侧的重要性。由于
Presto
是分布式系统,因此
Join
可
以在一个集群的工作节点上并行执行,每个工作节点处理
Join
的一部分任务。要执行分布式
Join
,数
据可能需要在网络上分发。根据数据的形状,不同
的策略效率可能差别很大。
1.
广播
Join
策略
在
广播
Join
策略
中,
Join
的构建侧广播到并行执行
Join
的所有工作节点上
。换句话说,
每个工作节点上的
Join
都
得到构建侧数据的一个完整副本(如图
4-12
所示)。只有当探测
侧在工作节点上无重复地分布时,这种策略才会提供正确的语义,否则会产生重复数据。
工作节点
1
工作节点
2
工作节点
3
Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.
Start your free trial
You might also like
大数据项目管理:从规划到实现
Ted Malaska, Jonathan Seidman
数据库系统内幕
Alex Petrov
云原生:运用容器、函数计算和数据构建下一代应用
Boris Scholl, Trent Swanson, Peter Jausovec
Google系统架构解密: 构建安全可靠的系统
Heather Adkins, Betsy Beyer, Paul Blankinship, Piotr Lewandowski, Ana Oprea, Adam Stubblefield
Publisher Resources
ISBN: 9787115560056