doris通过rollup增加duplicate模型前缀索引

因为建表时已经指定了列顺序,所以一个表只有一种前缀索引。这对于使用其他不能命
中前缀索引的列作为条件进行的查询来说,效率上可能无法满足需求。因此,我们可以通过
创建 ROLLUP 来人为的调整列顺序。举例说明。
Base 表结构如下:
doris通过rollup增加duplicate模型前缀索引_第1张图片
可以看到,ROLLUP 和 Base 表的列完全一样,只是将 user_id 和 age 的顺序调换了。那
么当我们进行如下查询时:
SELECT * FROM table where age=20 and message LIKE “%error%”;
会优先选择 ROLLUP 表,因为 ROLLUP 的前缀索引匹配度更高。
与此同时物化视图同样可以实现类似功能
用户的原始表有 (k1, k2, k3) 三列。其中 k1, k2 为前缀索引列。这时候如果用户查询条件中包含 where k1=1 and k2=2 就能通过索引加速查询。

但是有些情况下,用户的过滤条件无法匹配到前缀索引,比如 where k3=3。则无法通过索引提升查询速度。

创建以 k3 作为第一列的物化视图就可以解决这个问题。

创建物化视图

CREATE MATERIALIZED VIEW mv_1 as SELECT k3, k2, k1 FROM tableA ORDER BY k3;
通过上面语法创建完成后,物化视图中既保留了完整的明细数据,且物化视图的前缀索引为 k3 列。表结构如下:
doris通过rollup增加duplicate模型前缀索引_第2张图片

你可能感兴趣的:(数据仓库,doris,数据仓库)