日期:2014-05-16  浏览次数:20416 次

Oracle视图的使用

Oracle视图的使用

1.视图的概念

    视图是基于一张表或多张表或另外一个视图的逻辑表。视图不同于表,视图本身不包含任何数据。表是实际独立存在的实体,是用于存储数据的基本结构。而视图只是一种定义,对应一个查询语句。视图的数据都来自于某些表,这些表被称为基表。通过视图来查看表,就像是从不同的角度来观察一个(或多个)表。视图可以在表能够使用的任何地方使用,但在对视图的操作上同表相比有些限制,特别是插入和修改操作。对视图的操作将传递到基表,所以在表上定义的约束条件和触发器在视图上同样起作用。

2.视图的优点:

*   可以提高数据访问的安全性,通过视图往往只可以访问数据库中表的特定部分,限制了用户访问表的全部行和列。

*   简化了对数据的查询,隐藏了查询的复杂性。视图的数据来自一个复杂的查询,用户对视图的检索却很简单。

*   一个视图可以检索多张表的数据,因此用户通过访问一个视图,可完成对多个表的访问。

*   视图是相同数据的不同表示,通过为不同的用户创建同一个表的不同视图,使用户可分别访问同一个表的不同部分。

      

3.创建视图

创建视图需要CREAE VIEW系统权限,视图的创建语法如下:

CREATE [OR REPLACE] [FORCE|NOFORCE] VIEW视图名[(别名1[,别名2...])]

AS 子查询

[WITH CHECK OPTION [CONSTRAINT 约束名]]

[WITH READ ONLY]

其中:

OR REPLACE 表示替代已经存在的视图。

FORCE表示不管基表是否存在,创建视图。

NOFORCE表示只有基表存在时,才创建视图,是默认值。

USER_VIEWS字典中包含了视图的定义。

 

4.物化视图

      物化视图是一种特殊的物理表,“物化”(Materialized)视图是相对普通视图而言的。普通视图是虚拟表,应用的局限性大,任何对视图的查询,Oracle都实际上转换为视图SQL语句的查询。这样对整体查询性能的提高,并没有实质上的好处。
     物化视图的类型ON DEMANDON COMMIT。二者的区别在于刷新方法的不同,ON DEMAND顾名思义,仅在该物化视图“需要”被刷新了,才进行刷新(REFRESH),即更新物化视图,以保证和基表数据的一致性;而ON COMMIT是说,一旦基表有了COMMIT,即事务提交,则立刻刷新,立刻更新物化视图,使得数据和基表一致。
物化视图可以分为以下三种类型:包含聚集的物化视图;只包含连接的物化视图;嵌套物化视图。三种物化视图的快速刷新的限制条件有很大区别,而对于其他方面则区别不大。

 

    创建物化视图时可以指定多种选项
   * 创建方式(Build Methods):包括