Oracle 19c 中的物化视图是一种强大的数据库对象,它 存储了查询结果的物理副本,并可以定期或根据特定条件刷新以保持与基础数据的相对同步。它与普通视图(仅存储查询定义)的关键区别在于它实际存储了数据,从而显著提高复杂查询的性能,尤其是在数据仓库和报表场景中。
以下是 Oracle 19c 物化视图的核心概念、特性和管理要点:
一、 核心概念与目的:
物理存储数据: 将
SELECT 语句的结果集持久化地存储在数据库表段中。
性能提升: 对复杂、聚合或涉及大表连接的查询,直接查询预计算好的物化视图比执行原始查询快得多。
数据复制/分发: 常用于跨数据库(如主库到备库、中心到分支)复制和同步数据子集。
查询重写: Oracle 优化器能自动将针对基表的查询重写为使用已存在的物化视图(如果更高效且启用了此功能)。
减少网络负载: 在分布式系统中,本地物化视图可以减少远程查询。
-
关键特性:
刷新机制: 这是物化视图的核心管理点。Oracle 19c 支持:
COMPLETE:完全刷新。删除物化视图中所有数据,重新执行定义查询。简单可靠,但大数据量时资源消耗大、耗时长。FAST:快速刷新(增量刷新)。仅应用自上次刷新以来基表发生的更改(通过物化视图日志实现)。高效,但需要额外维护日志且仅支持特定查询类型(通常涉及聚合或连接)。 -
FORCE:默认选项。Oracle 尝试使用FAST 刷新;如果FAST 不可用,则回退到COMPLETE。 -
ON COMMIT:在基表的事务提交时 自动进行FAST 刷新。确保物化视图与基表高度实时同步,但会增加基表事务的开销。 -
ON DEMAND:需要 手动调用DBMS_MVIEW.REFRESH 或通过调度任务(DBMS_SCHEDULER/DBMS_JOB)刷新。提供最大的刷新控制。 -
物化视图日志: 对于支持
FAST 刷新的物化视图,必须在基表上创建物化视图日志。该日志记录基表上发生的 DML 操作(INSERT, UPDATE, DELETE),供快速刷新过程使用。 -
查询重写:
启用 (
ENABLE QUERY REWRITE) 后,优化器在满足条件时会透明地将针对基表的查询重写为使用物化视图。 -
需要
QUERY REWRITE 权限和合适的初始化参数设置 (QUERY_REWRITE_ENABLED = TRUE,QUERY_REWRITE_INTEGRITY 设置信任级别)。 -
构建方式:
IMMEDIATE:创建物化视图时立即执行定义查询并填充数据。 -
DEFERRED:创建时为空的物化视图,后续需要手动刷新才能填充数据。 -
预建表: 允许使用现有表作为物化视图的存储容器。
-
分区物化视图: 物化视图本身可以分区,提高管理性和查询性能。
-
实时物化视图: Oracle 12c 引入并在后续版本增强的特性。物化视图包含一个“陈旧”部分(上次刷新后的数据)和一个“实时”部分(通过联机重写直接访问基表的最新数据)。查询时自动结合这两部分,提供近乎实时的结果,而无需频繁的
ON COMMIT 刷新。在 19c 中此功能已相当成熟。二、创建基本语法:
CREATE MATERIALIZED VIEW [schema.]mv_name[BUILD {IMMEDIATE | DEFERRED}][REFRESH [FAST | COMPLETE | FORCE] [ON DEMAND | ON COMMIT] [START WITH start_time] [NEXT next_interval] [WITH {PRIMARY KEY | ROWID}] [USING {DEFAULT | <rollback_segment>} ...][ENABLE | DISABLE] QUERY REWRITEAS<select_statement>;三、管理与维护:
手动刷新:
EXEC DBMS_MVIEW.REFRESH('mv_name', method => 'F'); -- 'F' for FAST, 'C' for COMPLETEEXEC DBMS_MVIEW.REFRESH('mv_name, mv_name2', method => 'C'); -- Refresh multiple自动刷新: 使用
DBMS_SCHEDULER 或DBMS_JOB 创建定时任务调用DBMS_MVIEW.REFRESH。监控:
视图
USER_MVIEWS /ALL_MVIEWS /DBA_MVIEWS:物化视图定义、刷新状态、最后刷新时间等。视图
USER_MVIEW_REFRESH_TIMES:上次刷新时间戳。视图
USER_MVIEW_LOGS /DBA_MVIEW_LOGS:物化视图日志信息。视图
USER_REFRESH_DEPENDENCIES:物化视图的依赖关系。修改: 使用
ALTER MATERIALIZED VIEW 命令修改刷新方式、启用/禁用查询重写等(不能直接修改查询定义,通常需要重建)。删除:
DROP MATERIALIZED VIEW mv_name; (物化视图日志需要单独删除)。四、使用场景 4.1、性能优化场景(数据仓库与报表)
核心价值:预计算复杂查询,减少实时计算压力。
-
解决方案:创建
ON COMMIT刷新的物化视图,将多表连接结果物化。基表DML提交后自动刷新视图,业务进程直接查询物化视图,响应时间从秒级降至毫秒级。 -
技术要点:
CREATE MATERIALIZED VIEW IRDB_NETWORKLIST REFRESH FORCE ON COMMIT -- 提交时强制刷新(优先尝试FAST增量)AS SELECT ... FROM tableA, tableB, tableC ...; -- 复杂关联查询
电商销售日报分析
问题:每日统计大表(亿级订单)的销售额、地区排行等聚合查询耗时过长。
解决方案:创建按日分组的物化视图,定时全量刷新(如凌晨)。报表查询直接访问物化视图,性能提升10倍以上 6。
技术要点:结合
REFRESH COMPLETE ON DEMAND + DBMS_SCHEDULER定时任务。4.2、数据同步与分布式场景
核心价值:跨节点部分数据复制,降低网络负载。
-
解决方案:
呼叫节点创建FAST刷新物化视图,仅同步必要列:
CREATE MATERIALIZED VIEW T_USERINFO_MV REFRESH FAST WITH PRIMARY KEY -- 基于主键增量同步AS SELECT phonenumber, localid, brandid FROM T_USERINFO@dblink_admin;
通过
DBMS_REFRESH组每10秒批量刷新。效果:避免全库同步(如DG),仅传输增量变更,网络开销降低70%。
跨国企业区域数据本地化
问题:亚太区频繁查询欧美数据库的订单表,网络延迟高。
方案:在亚太数据库创建物化视图,按需刷新(如每小时),将远程数据本地化存储。
4.3、实时数据接入场景
核心价值:近实时数据整合,替代ETL批处理。
-
方案:
CREATE MATERIALIZED VIEW risk_trans_summary REFRESH FAST ON COMMIT -- 事务提交时增量刷新AS SELECT user_id, SUM(amount) FROM transactions GROUP BY user_id;
效果:基表提交后200ms内视图更新,查询直接命中聚合结果。
流式数据预处理
物联网设备日志按
ROWID创建物化视图日志,FAST刷新过滤异常数据,供实时告警使用。
五、技术选型与最佳实践
-
物化视图日志设计原则
主键 vs ROWID:
主键日志:需基表有主键,支持多表连接视图。
ROWID日志:单表简单聚合,不支持连接(因连接后行标识丢失)。
-
日志优化:定期清理高水位线,对
MLOG$_表建索引避免全表扫描。建议:
延迟敏感且基表事务频繁 →
ON COMMIT + 主键日志海量数据跨库同步 →
FAST +ON DEMAND定时任务历史数据分析 →
COMPLETE刷新 + 列存储压缩通过物化视图,可在性能、实时性、资源开销间取得平衡,是Oracle数据架构优化的利器
编辑推荐:
- oracle优化利器之 物化视图03-03
- Oracle高级技术——CTE03-03
- oracle数据恢复—oracle数据库误执行truncate命令导致数据丢失怎么办?03-03
- 白象“多半”商标上热搜,“擦边”是这个时代的营销语言03-03
- 亚朵枕套翻车03-03
- 查看oracle是noncdb 还是cdb的方法03-03
- 使用benchmarksql测试数据库处理能力03-03
- 数据丢失使用RMAN恢复教程03-03
下一篇: -
雷神推出 MIX PRO II 迷你主机:基于 Ultra 200H,玻璃上盖 + ARGB 灯效
2 月 9 日消息,雷神 (THUNDEROBOT) 现已宣布推出基于英
-
制造商 Musnap 推出彩色墨水屏电纸书 Ocean C:支持手写笔、第三方安卓应用
2 月 10 日消息,制造商 Musnap 现已在海外推出一款 Oce
刷新方式对比
刷新类型 适用场景 前提条件 性能影响 ON COMMIT秒级延迟场景 基表需创建物化视图日志 事务提交时额外开销 FAST大表增量同步 必须建日志,且查询符合快速刷新约束 低开销,依赖日志量 COMPLETE小表/无日志场景 无要求 全量重建,资源消耗大 ON DEMAND允许延迟的批处理 可搭配定时任务 可控的异步刷新 相关推荐
热文推荐
- Oracle高级技术——CTE
Oracle高级技术——CTE
26-03-03 - oracle数据恢复—oracle数据库误执行truncate命令导致数据丢失怎么办?
- 白象“多半”商标上热搜,“擦边”是这个时代的营销语言
白象“多半”商标上热搜,“擦边”是这个时代的营销语言
26-03-03 - 亚朵枕套翻车
亚朵枕套翻车
26-03-03 - 王自如走上了罗永浩的老路
王自如走上了罗永浩的老路
26-03-03 - 一次Oracle的非正常关闭
一次Oracle的非正常关闭
26-03-03 - DeepSeek一键生成网页版SQL生成器(科技感十足)
DeepSeek一键生成网页版SQL生成器(科技感十足)
26-03-03 - 苹果打起价格战,国产手机只能靠边站
苹果打起价格战,国产手机只能靠边站
26-03-03 - 免费获得 Oracle MOS 账号的秘密,技术爱好者必看!
免费获得 Oracle MOS 账号的秘密,技术爱好者必看!
26-03-03 - 呼唤县城老表,快来买新能源车
呼唤县城老表,快来买新能源车
26-03-03
实时物化视图(12c+特性增强)
案例:风险监控系统需即时统计交易流水。
移动彩铃业务的多节点同步
需求:管理节点需向5个呼叫节点同步用户表(
T_USERINFO)的部分字段(如手机号、品牌ID)。
电信业务初始化数据加载
问题:进程启动需从4个表关联查询全球运营商数据(networkid、cc、ndc等),频繁访问导致性能瓶颈。
