视图

永不放弃,一切皆有可能!!!

只为成功找方法,不为失败找借口!

视图

1.定义

 

  •        视图(view),也称虚表, 在系统的数据字典中仅存放了视图的定义,不存放视图对应的数据。每次使用的时候,只是重新执行SQL.
  •        视图是从一个或多个实际表中获得的,这些表的数据存放在数据库中。那些用于产生视图的表叫做该视图的基表。一个视图也可以从另一个视图中产生。
  •        视图的定义存在数据库中,与此定义相关的数据并没有再存一份于数据库中。通过视图看到的数据存放在基表中。
  •        视图看上去非常象数据库的物理表,对它的操作同任何其它的表一样。当通过视图修改数据时,实际上是在改变基表中的数据(某些视图仅用于查询);相反地,基表数据的改变也会自动反映在由基表产生的视图中。
  •        还有一种视图:物化视图(MATERIALIZED VIEW ),也称实体化视图,快照 (8i 以前的说法) ,它是含有数据的,占用存储空间。

 

2.视图优点

 

    1)安全性

       通过视图用户只能查询和修改他们所能见到的数据。数据库中的其它数据则既看不见也取不到。通过Oracle视图,用户可以被限制在数据的不同子集上

 

   2)逻辑数据独立性。

       视图可帮助用户屏蔽真实表结构变化带来的影响。视图可以使应用程序和数据库表在一定程度上独立。

    如果没有视图,应用一定是建立在表上的。有了视图之后,程序可以建立在视图之上,从而程序与数据库表被视图分割开来。视图可以在以下几个方面使程序与数据独立:

       1. 如果应用建立在数据库表上,当数据库表发生变化时,可以在表上建立视图,通过视图屏蔽表的变化,从而应用程序可以不动。

       2. 如果应用建立在数据库表上,当应用发生变化时,可以在表上建立视图,通过视图屏蔽应用的变化,从而使数据库表不动。

       3. 如果应用建立在视图上,当数据库表发生变化时,可以在表上修改视图,通过视图屏蔽表的变化,从而应用程序可以不动。

       4.  如果应用建立在视图上,当应用发生变化时,可以在表上修改视图,通过视图屏蔽应用的变化,从而数据库可以不动。

 

   3)简单性

   视图不仅可以简化用户对数据的理解,也可以简化他们的操作。那些被经常使用的查询可以被定义为视图,从而使用户不必为以后的操作每次都指定全部的条件

 

   4) 可以合并分离的数据,创建分区视图  

 

3.视图限制性

 

—      1)性能的降低:

    SQL Server必须把对视图的查询转化成对基本表的查询,如果这个视图是由一个复杂的多表查询所定义,即使是对视图的一个简单查询,SQL Server也把它变成一个复杂的对基础表的连接查询,会产生一定的时间开销。

 

—      2) 修改的限制:

    当用户要修改视图的某些行时,SQL Server必须把它转化为对基本表行的修改。对于简单的视图来说,这是很方便的,但是,对于比较复杂的视图来说,这可能是不可修改的。

 

4.创建视图

 

复制代码
CREATE[OR REPLACE][FORCE][NOFORCE]VIEW view_name

[(column_name)[,….n]]

AS

Select_statement

[WITH CHECK OPTION[CONSTRAINT constraint_name]]

[WITH READ ONLY]
复制代码

 

  1)说明:

 

    view_name :  视图的名字

    column_name: 视图中的列名 (在下列情况下 , 必须指定视图列的名称 1)由算术表达式 , 系统内置函数或者常量得到的列2)共享同一个表名连接得到的列3) 希望视图中的列名与表中的列名不同的时候)

    REPLACE:  如果创建视图时, 已经存在此视图, 则重新创建此视图, 相当于覆盖

    FORCE:  强制创建视图, 无论的视图所依赖的基表否存在或是否有权限创建

    NOFORCE:  只有基表存在且具有创建视图权限时, 才可以创建视图

    WITH CHECK OPTION  指出在视图上所进行的修改都要符合select_statement 所指定的限制条件

    WITH READ ONLY  只允许查看视图

 

  2)视图的定义原则: 


       1. 在没有 WITH CHECK OPTION 和 READ ONLY的情况下,查询中不能使用ORDER BY子句; 
       2. 如果没有为 CHECK OPTION 约束命名,系统会自动为之命名,形式为 SYS_Cn;
 

 

5.视图基本操作

 

  1. 查询视图: 可依赖于多个基表.    SELECT  * FROM view_name; /* 类似于查询表数据*/

  2. 插入数据   INSERT  INTO  view_name VALUES();

  3. 修改数据:  UPDATE  view_name SET …  (若一个视图依赖于多个基本表, 则一次修改该视图只能修改一个基本表的数据.)

  4. 删除数据:  Delete from view_name where …

  5. 删除视图:  DROP VIEW view_name;  (只有视图所有者和具备DROP VIEW 权限的用户可以删除视图。删除视图的定义不影响基表中的数据。视图被删除后,基于被删除视图的其他视图或应用将无效。)

     注意:对视图的增删改都是在基表的基础上

 

 

6.视图操作限制

 

  1)在视图定义中没有设定READ ONLY 的前提下, 如果视图包含了下面的内容, 那么不能通过视图删除表中的数据:

    分组函数, 如SUM,AVG,MIN,MAX 等

    GROUP BY 子句

    包含了表达式

    ROWNUM 伪列

 

  2)插入数据时, 除了满足上面的条件外, 还需要保证那些没有包含在视图定义中的基表的列必须允许空值. 如果在视图定义中还包含了WITH CHECK OPTION 子句, 那么对视图的修改除了前面的那些原则外, 还必须满足指定的约束条件

  

  3)  在没有 WITH CHECK OPTION 和 READ ONLY的情况下,查询中不能使用 ORDER BY子句; 


     4)  如果没有为 CHECK OPTION 约束命名,系统会自动为之命名,形式为 SYS_Cn;

 

 

 

posted @ 2016-09-19 21:24  时光太浅爱太深  阅读(291)  评论(0编辑  收藏  举报