当前位置:   article > 正文

Kylin构建引擎的衍生维度_kylin 衍生维度

kylin 衍生维度

1. 衍生维度(derived dimension)

衍生维度的构建和查询过程

当有一张事实表和维度表如下:

事实表和维度表

我们需要以city为维度字段,sum(salary)为度量字段,进行cube的构建。因为定义了city为衍生维度字段,所以构建的时候会用维度表的主键字段depart_no替换city字段,进行cube的构建,做了一次轻量的聚合。同时kylin会在底层记录主键字段depart_no与city字段的映射关系。构建的cube如下:
构建的cube
进行select city, sum(salary) from employee a join department b on a.depart_no = b.depart_no group by city查询的时候,会先用city字段替换主键字段depart_no,替换后的表如下:

替换后的表
再对替换后的表,进行最终的结果聚合

衍生维度的总结
所以当维度表有多个字段进行cube的构建,比如3个字段,则cuboid的个数由7个变成1个。加快了cube的构建速度。但是查询的时候需要做字段替换和聚合操作,降低了查询速度所以如何查询时的聚合操作工作量很大,则不建议使用衍生维度

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/从前慢现在也慢/article/detail/697686
推荐阅读
相关标签
  

闽ICP备14008679号