Details
-
Improvement
-
Status: Closed
-
Major
-
Resolution: Fixed
-
None
-
None
Description
Current implementation of incremental Materialized can not be used if any of the Materialized view source tables has update or delete operation since the last rebuild. In such cases a full rebuild should be performed.
Steps to enable incremental rebuild:
1. Introduce a new virtual column to mark a row deleted
2. Execute the query in the view definition
2.a. Add filter to each table scan in order to pull only the rows from each source table which has a higher writeId than the writeId of the last rebuild - this is already implemented by current incremental rebuild
2.b Add row is deleted virtual column to each table scan. In join nodes if any of the branches has a deleted row the result row is also deleted.
We should distinguish two type of view definition queries: with and without Aggregate.
3.a No aggregate path:
Rewrite the plan of the full rebuild to a multi insert statement with two insert branches. One branch to insert new rows into the materialized view table and the second one for insert deleted rows to the materialized view delete delta.
3.b Aggregate path: TBD
Prerequisite:
source tables haven't compacted since the last MV revuild
Attachments
Issue Links
- is related to
-
HIVE-18839 Implement incremental rebuild for materialized views (only insert operations in source tables)
- Closed
- relates to
-
HIVE-24855 Introduce virtual colum ROW__IS__DELETED
- Closed
-
HIVE-24992 Incremental rebuild of MV having aggregate in presence of delete operation
- Resolved
-
HIVE-24991 Enable fetching deleted rows in vectorized mode
- Closed
-
HIVE-25066 Show whether a materialized view supports incremental rebuild or not
- Closed
- links to