达梦物化视图怎么实现增量数据实时更新

概念

物化视图和普通视图有什么区别?
物化视图实际有个对应的物理表真正存储数据,不需要在查询物化视图时查对应的基表数据而是直接查物化视图表的数据。
和普通视图比较,减少了对基表的访问压力,但存在一个问题,如果物化视图对应的基表数据有更新,物化视图表中的数据就变得陈旧,需要有个策略来保障物化视图的数据同步更新。
而保障这个同步更新,实际是通过创建一些基表日志表、基表触发器、库级触发器来实现同步更新的
如果要使用物化视图,需要在性能和数据实时性之间进行权衡取舍,做合理的设计。

底层实现原理

物化视图怎么来保障数据的同步更新呢?
在创建物化视图时,系统会对应生成一个物理表,物理表对象名是“MTAB$_”+视图对象名,即在创建的物化视图名为V_TEST,同时会对应的创建一个物理表MTAB$_V_TEST;
系统再根据刷新策略来更新这个物理表数据,从而实现数据的同步更新。
刷新策略由三部分组成:刷新方法+刷新时机+刷新规则

刷新方法

3个选项:
FAST:根据相关表上的数据更改记录进行增量刷新,普通DML操作生成的记录存在于物化视图日志。使用FAST刷新之前,必须先建好物化视图日志
物化视图日志表建好后会自动创建一个基表的表级触发器,来记录基表的数据变化,实现增量数据的同步。
例如创建TEST1表的物化视图日志,会对应的创建一个命名为MTRG$

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值