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 里的两条记录被标记为 "已处理",后续会自动清理。

相关推荐
苦学编程的谢2 小时前
Redis_12_持久化(1)
数据库·redis·缓存
百***46802 小时前
MySQL的底层原理与架构
数据库·mysql·架构
百***12222 小时前
Redis开启远程访问
数据库·redis·缓存
czhc11400756632 小时前
Java1112 基类 c#vscode使用 程序结构
android·java·数据库
倔强的石头_3 小时前
openGauss实战:Python开发与AI向量数据库应用
数据库
马克学长3 小时前
SSM快递代收系统00pay(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库
谅望者4 小时前
数据分析笔记07:Python编程语言介绍
大数据·数据库·笔记·python·数据挖掘·数据分析
面向星辰4 小时前
sql基本增删改查语句汇总
数据库·sql·mybatis
一氧化二氢.h5 小时前
MySQL root用户连接错误解决方法
android·数据库·mysql