oracle 物化视图设置自动更新日志

从初始阶段创建基本数据

1.创建原始表 t_order(含测试数据)

csharp 复制代码
CREATE TABLE t_order 
(order_id NUMBER PRIMARY KEY, pay_amount NUMBER(10,2), pay_status NUMBER, create_time DATE);
INSERT INTO t_order VALUES 
(1, 199.99, 1, TO_DATE('2025-01-15', 'YYYY-MM-DD'));
COMMIT;

2.创建物化视图日志(自动生成 MLOG$_T_ORDER)

(ps:MLOG$_T_ORDER 是 Oracle 数据库中 物化视图日志(Materialized View Log) 的系统生成表名,核心用于支持快速刷新物化视图,记录基表(这里是 T_ORDER 表)的数据变更(增删改))

csharp 复制代码
CREATE MATERIALIZED VIEW LOG 
    ON t_order WITH PRIMARY KEY, ROWID (pay_amount, pay_status, create_time) 
    INCLUDING NEW VALUES;

3.创建增量物化视图 mv_order_stat_incr

csharp 复制代码
CREATE MATERIALIZED VIEW mv_order_stat_incr
REFRESH FAST ON DEMAND
AS
SELECT TRUNC(create_time) AS stat_date, COUNT(order_id) AS order_count, SUM(pay_amount) AS total_amount
FROM t_order WHERE pay_status = 1 GROUP BY TRUNC(create_time);

此时,mv_order_stat_incr 里已经有一条数据

stat_date=2025-01-15,order_count=1,total_amount=199.99;

MLOG$_T_ORDER 里暂时没有记录(因为创建物化视图后,还没修改过 t_order)。

修改原始表 t_order

csharp 复制代码
//新增一条已付款订单
INSERT INTO t_order VALUES (2, 299.99, 1, TO_DATE('2025-01-15', 'YYYY-MM-DD'));
//修改一条订单:从已付款(1)改成未付款(0)
UPDATE t_order SET pay_status=0 WHERE order_id=1;
COMMIT;  // 提交后,Oracle 自动往 MLOG$_T_ORDER 写两条变更记录

此时 MLOG$_T_ORDER 里有两条记录

(ps:是你执行 CREATE MATERIALIZED VIEW LOG ON t_order 后,Oracle 自动创建的系统日志表不是你手动建的)

一条是 INSERT 操作

order_id=2,pay_amount=299.99,pay_status=1;

一条是 UPDATE 操作

order_id=1,旧 pay_status=1,旧 pay_amount=199.99,新 pay_status=0;

手动执行增量命令

csharp 复制代码
EXEC DBMS_MVIEW.REFRESH('mv_order_stat_incr', 'F');

对 INSERT 记录

stat_date=2025-01-15 的 order_count+1(变成 2),

total_amount+299.99(变成 199.99+299.99=499.98);

对 UPDATE 记录

stat_date=2025-01-15 的 order_count-1(变成 1),

total_amount-199.99(变成 499.98-199.99=299.99);

最终 mv_order_stat_incr 的数据变成

stat_date=2025-01-15,order_count=1,total_amount=299.99(和 t_order 最新状态一致);

MLOG$_T_ORDER 里的两条记录被标记为 "已处理",后续会自动清理。

相关推荐
十五年专注C++开发16 分钟前
浅谈Qt中的QSql模块整体设计
开发语言·数据库·c++·qt
TDengine (老段)27 分钟前
TDengine 生态系统连接指南
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
k***921631 分钟前
C++:继承
java·数据库·c++
一只旭宝1 小时前
Linux专题十二:mysql数据库以及redis数据库
linux·数据库·mysql
萧曵 丶1 小时前
MySQL B+树详解
数据库·b树·mysql
鱼跃鹰飞1 小时前
面试题:Spring事务失效的八大场景
数据库·mysql·spring
ss2732 小时前
类的线程安全:多线程编程-银行转账系统:如果两个线程同时修改同一个账户余额,没有适当的保护机制,会发生什么?
java·开发语言·数据库
郑泰科技2 小时前
windows下启动hbase的步骤
数据库·windows·hbase
子一!!2 小时前
MySQL数据库基础操作
数据库·mysql·oracle
DarkAthena2 小时前
【GaussDB】从 sqlplus 到 gsql:Shell 中执行 SQL 文件方案的迁移与改造
数据库·sql·oracle·gaussdb