视图

什么是视图

  视图是一个虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。行和列数据来自由定义视图的查询所引用的表,并且在引用视图时动态生成。对其中所引用的基础表来说,视图的作用类似于筛选。定义视图的筛选可以来自当前或其它数据库的一个或多个表,或者其它视图。通过视图进行查询没有任何限制,通过它们进行数据修改时的限制也很少。
  视图是存储在数据库中的查询的SQL 语句,它主要出于两种原因:安全原因, 视图可以隐藏一些数据,如:社会保险基金表,可以用视图只显示姓名,地址,而不显示社会保险号和工资数等,另一原因是可使复杂的查询易于理解和使用。这个视图就像一个“窗口”,从中只能看到你想看的数据列。这意味着你可以在这个视图上使用SELECT *,而你看到的将是你在视图定义里给出的那些数据列:
  既然视图的定义是基于基本表的,哪为什么还要定义视图呢?这是因为合理地使用视图能够带来许多好处:

  1. 视图能简化用户操作。视图机制使用户可以将注意力集中在所关心地数据上。如果这些数据不是直接来自基本表,则可以通过定义视图,使数据库看起来结构简单、清晰,并且可以简化用户的的数据查询操作。例如,那些定义了若干张表连接的视图,就将表与表之间的连接操作对用户隐藏起来了。换句话说,用户所作的只是对一个虚表的简单查询,而这个虚表是怎样得来的,用户无需了解。
  2. 视图使用户能以多种角度看待同一数据。视图机制能使不同的用户以不同的方式看待同一数据,当许多不同种类的用户共享同一个数据库时,这种灵活性是非常必要的。
  3. 视图对重构数据库提供了一定程度的逻辑独立性。数据的物理独立性是指用户的应用程序不依赖于数据库的物理结构。数据的逻辑独立性是指当数据库重构造时,如增加新的关系或对原有的关系增加新的字段,用户的应用程序不会受影响。层次数据库和网状数据库一般能较好地支持数据的物理独立性,而对于逻辑独立性则不能完全的支持。
  4. 视图能够对机密数据提供安全保护
  5. 适当的利用视图可以更清晰地表达查询

视图操作

  创建视图需要有CREATE VIEW权限,并且对于查询涉及到的列有SELECT权限。如果使用CREATE OR REPLACE或者ALTER修改视图,还需要DROP权限。在创建视图前要先查看权限:

SELECT SELECT_priv,create_view_priv from mysql.user WHERE user='username'

  MYSQL视图定义有一些限制,在FROM关键字后面不能包含子查询,如果必须使用,可以将子查询定义成一个视图,然后对该视图再创建视图就可以使用类似的功能了。

  WITH [ CASCADED l LOCAL ] CHECK OPTION决定了是否允许更新数据使记录不再满足视图条件。LOCAL只要求视图满足本视图的条件就可以更新;CASCADED则是必须满足所有针对该视图的所有视图的条件才可以更新。默认是CASCADED。

   用户可以一次删除一个或多个视图,前提是必须具有该视图的DROP权限。

  使用SHOW TABLES命令时不仅显示表的名字,同时也会显示视图的名字。使用SHOW TABLES STATUS命令,不断可以显示表的信息,也可以显示视图信息。

  如果需要查看视图的定义,可以使用SHOW CREATE VIEW命令。

  视图除了进行查询记录外,也可以利用视图进行插入、更新、删除记录的操作,减少对基表中信息的直接操作,提高了数据的安全性。在视图上使用INSERT语句添加数据时,要符合以下规则:
  (1)使用INSERT语句向数据表中插入数据时,用户必须有插入数据的权利。
  (2)由于视图只引用表中的部分字段,所以通过视图插入数据时只能明确指定视图中引用的字段的取值。而那些表中并未引用的字段,必须知道在没有指定取值的情况下如何填充数据,因此视图中未引用的字段必须具备下列条件之一。
         该字段允许空值。
         该字段设有默认值。
         该字段是标识字段,可根据标识种子和标识增量自动填充数据。
         该字段的数据类型为timestamp或uniqueidentifier。
  (3)视图中不能包含多个字段值的组合,或者包含使用统计函数的结果。
  (4)视图中不能包含DISTINCT或GROUP BY子句。
  (5)如果视图中使用了WITH CHECK OPTION,那么该子句将检查插入的数据是否符合视图定义中SELECT语句所设置的条件。如果插入的数据不符合该条件,SQL Server会拒绝插入数据。
  (6)不能在一个语句中对多个基础表使用数据修改语句。因此,如果要向一个引用了多个数据表的视图添加数据时,必须使用多个INSERT语句进行添加。

posted @ 2016-07-27 21:48  简单爱_wxg  阅读(385)  评论(0编辑  收藏  举报