分布式数据库之火山模型

概念

火山模型又叫迭代器模型。

  • IO墙效应

在90年代早期,计算机的内存资源十分昂贵,相对于CPU的执行效率,IO效率要差得多,因此运算符和存储之间的IO交换是影响查询效率的主要因素(IO墙效应)。

火山模型将更多的内存资源用于IO的缓存设计而 没有优化CPU 的执行效率是在当时的硬件基础上很自然的权衡。

火山模型

在这里插入图片描述

设计思路

将关系代数当中的每一个算子抽象成一个迭代器。
每个迭代器都带有一个 next 方法。
每次调用这个方法将会返回这个算子的产生的一行数据(或者说一个 Tuple)。
程序通过在 SQL 的计算树的根节点不断地调用 next方法来获得整个查询的全部结果。

示例

 SELECT col1 FROM table1 WHERE col2 > 0;

这条 SQL 就可以被翻译成由三个算子组成的计算树。
如上图所示,可以使用伪代码将这三个算子的执行逻辑表示出来。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值