0

0

如何配置物化视图的ON COMMIT刷新_提交即刷新的延迟与性能开销评估

P粉602998670

P粉602998670

发布时间:2026-03-16 12:24:28

|

765人浏览过

|

来源于php中文网

原创

会,ON COMMIT刷新会卡住事务,因每次COMMIT前必须完成MV刷新,导致写入延迟激增、锁争用加剧,仅适用于写入极低且实时性要求苛刻的场景。

ON COMMIT 刷新会卡住你的事务吗?

会,而且卡得挺实在。只要物化视图定义里写了 refresh on commit,每次执行 commit 时,数据库必须先完成刷新(包括查询基表、计算差异、更新 mv 日志、写入 mv 表),才能真正提交事务。这意味着:事务的响应时间直接受 mv 刷新耗时支配。

常见错误现象:ORA-12054: cannot set the ON COMMIT refresh attribute for the materialized view(权限或 MV 日志缺失)、ORA-12008: error in materialized view refresh path(基表变更触发刷新失败,导致整个事务回滚)。

  • 必须确保基表已建好 MATERIALIZED VIEW LOG,且包含所有 SELECT 列和 WITH ROWIDWITH PRIMARY KEY
  • ON COMMIT 不支持含聚合、分析函数、远程表、非确定性函数(如 SYS_GUID())的 MV 定义
  • 多个 ON COMMIT MV 同时依赖同一张基表时,一个刷新失败会导致所有相关事务失败

为什么不用 ON COMMIT 却总被推荐?

因为它语义最干净:数据一致性由数据库内核保证,应用层完全不用操心“什么时候同步”。但代价是把延迟从查询侧(REFRESH ON DEMAND)转移到了写入侧。

使用场景非常窄:仅适用于基表写入频率极低(比如每小时才几笔)、且下游查询对实时性要求苛刻到“不能容忍毫秒级不一致”的系统(例如某些风控规则引擎)。大多数 OLTP 场景下,它反而成了性能瓶颈放大器。

  • 写入吞吐量下降明显:单次 INSERT + COMMIT 可能从 2ms 拉长到 200ms+
  • 并发写入时容易出现锁争用——MV 刷新过程会对基表 MV 日志加行锁,甚至可能锁住 MV 表本身
  • Oracle 12c+ 虽支持并行刷新,但 ON COMMIT 强制串行执行,无法受益

怎么测出真实延迟和开销?

别信文档里的“平均值”,直接在生产镜像环境跑压测。核心是分离测量:只测刷新本身耗时,排除网络、客户端、应用逻辑干扰。

实操建议:

课游记AI
课游记AI

AI原生学习产品

下载
  • DBMS_MVIEW.REFRESH 手动触发一次 ON COMMIT 类型的 MV 刷新,配合 V$SESSION_EVENT 查看等待事件(重点关注 enq: MV - contentionlog file sync
  • 在事务中插入一条记录后立即 COMMIT,用 DBMS_UTILITY.GET_TIME 套住整个块,反复执行 100 次取 P95 延迟
  • 对比关闭 MV 后的同操作耗时,差值就是纯刷新开销;再对比 REFRESH ON DEMAND 的手动刷新耗时,能看出“延迟转移”是否可接受

示例(测单次开销):

DECLARE
  t1 NUMBER; t2 NUMBER;
BEGIN
  t1 := DBMS_UTILITY.GET_TIME;
  INSERT INTO orders VALUES (1001, 'A', SYSDATE);
  COMMIT; -- 此处触发 ON COMMIT 刷新
  t2 := DBMS_UTILITY.GET_TIME;
  DBMS_OUTPUT.PUT_LINE('Commit + refresh took: ' || (t2-t1)/100 || 's');
END;

替代方案比硬扛 ON COMMIT 更常用

绝大多数业务其实不需要“提交即可见”,只需要“秒级最终一致”。这时候 REFRESH FAST ON DEMAND 配合定时任务(如 DBMS_SCHEDULER 每 5 秒跑一次)更可控、更可扩展。

关键差异点:

  • ON COMMIT 是强同步、高延迟、难诊断;ON DEMAND 是弱同步、低写入开销、可监控可重试
  • 如果 MV 依赖多张表,ON COMMIT 要求所有基表都带日志且兼容;FAST 刷新在部分表无日志时会自动退化为 COMPLETE,而 ON COMMIT 直接报错拒绝创建
  • Oracle 19c+ 支持 REFRESH EVERY n SECONDS(基于调度器的隐式周期刷新),语法简洁,但底层仍是 ON DEMAND 机制

真正复杂的地方在于:MV 日志的维护成本常被低估——它本身要写 redo、占存储、影响基表 DML 性能。哪怕不用 ON COMMIT,只要开了日志,就得持续评估它对主业务的影响。

数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

513

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

384

2023.10.25

oracle清空表数据
oracle清空表数据

当表中的数据不需要时,则应该删除该数据并释放所占用的空间。本专题为大家提供oracle清空表数据的相关文章,帮助大家解决该问题。

271

2023.08.16

Oracle中declare的使用
Oracle中declare的使用

Oracle DECLARE语句是PL/SQL编程语言中用于声明变量、常量、游标或异常的关键字。它的主要作用是在程序中定义这些对象,以便在后续的代码中使用。DECLARE语句的语法简单明了,可以根据需要声明多个对象。通过使用这些声明的对象,可以进行各种操作,如计算、查询数据库、处理异常等 。

221

2023.09.15

oracle怎么分页
oracle怎么分页

实现分页的步骤:1、使用ROWNUM进行分页查询;2、在执行查询之前进行设置分页参数;3、使用"COUNT(*)"函数来获取总行数,并使用"CEIL"函数来向上取整计算总页数;4、在外部查询中使用"WHERE"子句来筛选出特定的行号范围,以实现分页查询。想了解更多oracle怎么分页的文章,可以来阅读本专题先的文章。

248

2023.09.18

Oracle查看表操作历史记录
Oracle查看表操作历史记录

查看操作历史记录的方法:1、使用Oracle内置的审计功能,可以记录数据库中发生的各种操作,包括登录、DDL语句、DML语句等;2、使用Oracle日志文件,其中包含了数据库中发生的各种操作,可以通过查看日志文件来获取操作历史记录;3、使用Oracle的Flashback功能,可以查看数据库在某个时间点的操作历史记录;4、使用第三方工具等。本专题还提供其他查看表操作的文章,大家可以免费阅读。

464

2023.09.19

Oracle中RAC的用法
Oracle中RAC的用法

Oracle中RAC的用法:1、通过在多个服务器上运行数据库实例来提供高可用性;2、允许在需要时增加或减少节点数量;3、通过将工作负载分布到多个节点上来实现负载均衡;4、使用共享存储来实现多个节点之间的数据共享;5、允许多个节点同时处理数据库请求,从而实现并行处理;6、提供了透明故障切换功能;7、使用了一些技术来确保数据的一致性;8、提供了管理工具来简化RAC环境的管理和维护。本专题还提供RAC相关的其他文章,大家可以免费阅读。

452

2023.09.19

oracle imp
oracle imp

imp是Oracle数据库中的一个命令行工具,用于将导出的数据和对象从一个数据库实例导入到另一个数据库实例。imp命令的一般语法为“imp username/password@connect_string file=file_name [options]”。

342

2023.09.19

C++多线程并发控制与线程安全设计实践
C++多线程并发控制与线程安全设计实践

本专题围绕 C++ 在高性能系统开发中的并发控制技术展开,系统讲解多线程编程模型与线程安全设计方法。内容包括互斥锁、读写锁、条件变量、原子操作以及线程池实现机制,同时结合实际案例分析并发竞争、死锁避免与性能优化策略。通过实践讲解,帮助开发者掌握构建稳定高效并发系统的关键技术。

2

2026.03.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号