不支持重写
|
基本规则
|
- 查询需要的数据,视图无法满足,不支持重写。例如:查询:c1>=2,视图:c1>2,不支持重写。
- In、Like需要查询和视图条件完全匹配,不满足则不支持重写。例如:查询:in(2,3) ,视图: in(1,2,3),不支持重写。
- 查询SQL中已经使用了视图,不支持重写。
|
不支持重写
|
Join规则
|
- 只支持Inner-Join类型的重写,其他类型的Join在大部分场景下不支持重写。例如Outer-Join类型,只有当查询和视图完全一致时,才可以重写。
- 通过isValidPlan检查当前匹配的查询和视图的逻辑计划树是否满足最小单元的要求,只包含以下类型算子,不满足则不支持重写。
- LogicalRelation
- HiveTableRelation
- Project
- Filter
- Join
- SubqueryAlias
|
不支持重写
|
Aggregate规则
|
- 视图逻辑计划树根节点必须是Aggregate算子。像order by、having的根节点是Sort、Filter,这种视图不支持重写。
- 查询和视图逻辑计划树匹配,两边根节点都必须是Aggregate算子,然后会通过isValidPlan检查子树是否满足最小单元的要求,不满足则不支持重写。
- 查询中出现了视图中不存在的聚合函数,不支持重写。
- 查询group by字段是视图group by字段的子集,只支持对以下聚合函数(不带distinct,min/max除外)rollUp,不满足则不支持重写。
|
不支持提取视图
|
查询逻辑过于单一或者过于复杂
|
- 不支持从单表查询中提取物化视图。
- 查询中如果出现了多层嵌套子查询,只支持从最内层子查询中提取视图,而不支持从外层子查询提取物化视图。
- 不支持从含有临时表的子查询中提取物化视图。
|