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

相关推荐
渣波1 小时前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
倔强的石头_1 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
倔强的石头_4 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab5 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence5 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神5 天前
三、用户与权限管理
数据库·mysql
麦聪聊数据6 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_6 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡6 天前
【MySQL数据库】数据类型与表约束
数据库·mysql
曹牧6 天前
Oracle EXPLAIN PLAN
数据库·oracle