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

相关推荐
此生只爱蛋15 分钟前
【Redis】主从复制
数据库·redis
马猴烧酒.33 分钟前
【面试八股|JAVA多线程】JAVA多线程常考面试题详解
java·服务器·数据库
天天爱吃肉82181 小时前
跟着创意天才周杰伦学新能源汽车研发测试!3年从工程师到领域专家的成长秘籍!
数据库·python·算法·分类·汽车
大巨头1 小时前
sql2008 数据库分页语句
数据库
m0_715575341 小时前
使用PyTorch构建你的第一个神经网络
jvm·数据库·python
老邓计算机毕设2 小时前
SSM智慧社区家政服务系统80q7o(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架
松涛和鸣3 小时前
72、IMX6ULL驱动实战:设备树(DTS/DTB)+ GPIO子系统+Platform总线
linux·服务器·arm开发·数据库·单片机
likangbinlxa3 小时前
【Oracle11g SQL详解】UPDATE 和 DELETE 操作的正确使用
数据库·sql
r i c k3 小时前
数据库系统学习笔记
数据库·笔记·学习
野犬寒鸦4 小时前
从零起步学习JVM || 第一章:类加载器与双亲委派机制模型详解
java·jvm·数据库·后端·学习