[SQL Server系] -- 视图

时间:2023-01-18 15:24:10

1:定义

从用户角度来看,一个视图是从一个特定的角度来查看数据库中的数据。

从数据库系统内部来看,一个视图是由SELECT语句组成的查询定义的虚拟表。

从数据库系统内部来看,视图是由一张或多张表中的数据组成的,从数据库系统外部来看,视图就如同一张表一样,对表能够进行的一般操作都可以应用于视图,例如查询,插入,修改,删除操作等。

通俗的讲:假如现在有两张表,你需要选取两张表中的部分数据,将这些数据重新组成一张表,以便于查询,则可将这两张表的结果组成视图(相当于虚拟表)。

2:特点

  • 视图一经定义便存储在数据库中,与其相对应的数据并没有像表那样又在数据库中再存储一份,通过视图看到的数据只是存放在基本表中的数据。
  • 对视图的操作与对表的操作一样,可以对其进行查询、修改(有一定的限制)、删除。
  • 当对通过视图看到的数据进行修改时,相应的基本表的数据也要发生变化。
  • 若基本表的数据发生变化,则这种变化也可以自动地反映到视图中。

3:语法

CREATE VIEW 视图名
[WITH { ENCRYPTION | SCHEMABINDING | VIEW_METADATA }]
AS
SELECT 列1, 列2, ……, 列n
FROM 表名
[WHERE 从句]
[WITH CHECK OPTION]

eg:

删除视图:

DROP VIEW 视图名

假设有某个表结构如下:

[SQL Server系] -- 视图

但是由于社保号(ssn)等信息是需要保密的,不能随便查询,  但是某些列又必须查询,此时就可以使用视图把可以查询的列公开出来。

假如查询这些列:

[SQL Server系] -- 视图