Oracle中的视图和物化视图有什么区别?
当前回答
再加上迈克·麦卡利斯特相当彻底的回答……
物化视图只能设置为在编译器认为视图查询简单时,通过数据库检测更改来自动刷新。如果它被认为太复杂,它将无法设置本质上是内部触发器来跟踪源表中的更改,从而仅更新mview表中已更改的行。
在创建物化视图时,您会发现Oracle将mview和表都创建为同名的表,这可能会让人感到困惑。
其他回答
物化视图—磁盘上的一个表,其中包含查询的结果集
非物化视图——从底层表中提取数据的查询
物化视图是由选择查询驱动的数据的逻辑视图,但查询的结果将存储在表或磁盘中,查询的定义也将存储在数据库中。
实体化视图的性能比普通视图好,因为实体化视图的数据将存储在表中,表可以被索引,因此连接更快,连接是在实体化视图刷新时完成的,因此不需要每次都像视图那样触发连接语句。
其他不同之处在于,在视图中,我们总是获得最新数据,但在物化视图中,我们需要刷新视图以获得最新数据。 在物化视图的情况下,我们需要一个额外的触发器或一些自动方法,以便我们可以保持MV刷新,这对于数据库中的视图是不需要的。
物化视图是基于磁盘的,并根据查询定义定期更新。
视图仅为虚拟视图,并且在每次访问视图时运行查询定义。
视图使用查询从底层表中提取数据。
物化视图是磁盘上的一个表,其中包含查询的结果集。
物化视图主要用于在不可行或不希望使用应用索引的标准视图时提高应用程序性能。物化视图可以通过触发器或使用on COMMIT REFRESH选项定期更新。这确实需要一些额外的权限,但并不复杂。ON COMMIT REFRESH至少从Oracle 10开始就存在了。
视图本质上是由给定查询动态填充的逻辑表状结构。视图查询的结果不会存储在磁盘上的任何地方,并且在每次执行查询时都会重新创建视图。物化视图是存储在数据库中并写入磁盘的实际结构。它们根据创建时定义的参数进行更新。
推荐文章
- 是否有一种方法以编程方式滚动滚动视图到特定的编辑文本?
- LEFT OUTER JOIN如何返回比左表中存在的记录更多的记录?
- 如何用SQL语句计算百分比
- Postgres唯一约束与索引
- SQL Server动态PIVOT查询?
- MySQL对重复键更新在一个查询中插入多行
- 向现有表添加主键
- 使用电子邮件地址为主键?
- MySQL:如何复制行,但改变几个字段?
- 不能删除或更新父行:外键约束失败
- MongoDB在v4之前不兼容ACID意味着什么?
- SQL WHERE ID IN (id1, id2,…idn)
- 最常见的SQL反模式是什么?
- 如何在PostgreSQL中查看视图的CREATE VIEW代码?
- 错误:没有唯一的约束匹配给定的键引用表"bar"