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

相关推荐
卓怡学长3 分钟前
基于 SpringBoot 的生活信息分享平台,从 0 到 1 完整实现(附源码 + 数据库)
java·数据库·spring boot·tomcat·maven
ID_180079054735 分钟前
Python解析小红书(XHS)笔记评论 API,json数据返回参考
java·服务器·数据库
reasonsummer6 分钟前
【教学类-160-03】20260410 AI视频培训-练习3“豆包AI视频《孔子教育之旅》+豆包图片风格:中国风(平面图)”
数据库
曹牧10 分钟前
oracle kv字符串转换为多行两列
数据库·oracle
CV艺术家21 分钟前
java原mysql切换国产达梦数据库
数据库·mysql
好大哥呀22 分钟前
如何在Spring Boot中配置数据库连接?
数据库·spring boot·后端
xcLeigh28 分钟前
IoTDB数据订阅API实战:实时消费数据+TsFile订阅全攻略
数据库·api·iotdb·数据备份·tsfile·数据订阅
许杰小刀31 分钟前
使用 Python 将 Excel 数据批量导入到数据库中(SQLite)
数据库·python·excel
一个天蝎座 白勺 程序猿32 分钟前
Apache IoTDB(16):时序数据库的数据删除从单点精准清除到企业级数据生命周期管理
数据库·apache·时序数据库·iotdb
努力进修35 分钟前
【MySQL】90% 的 MySQL 性能问题都和它有关!索引的正确打开方式,看完少走 3 年弯路
数据库·mysql