为什么使用视图
视图是一个便利的方法,它只给用户对一个表的部分访问权限。视图可以限制将返回的记录以及可用的字段。所以授权用户对这个视图的访问权限而不是这个表本身来限制他们的访问权限。视图还是一个用于隐藏复杂语句和只显示给终端用户一个简单的单一表结果集的便利方法。
创建一个视图
SQL Server视图可以使用TSQL语句来创建或通过SQL Server Management Studio图形化地创建。对于第一个例子,我们将使用Management Studio和Adventure Works数据库(Adventure Works是Microsoft提供的一个免费测试数据库)。要开始,启动Management Studio,扩展开Databases,扩展开Adventure Works然后右键单击Views,选择New View。这将打开Add Table对话框。对于这个例子,我们将选择Person.Contact表。点击Add然后Close。这将出现如下所示的图形设计器。
图1
四个不同的面板组成了这个界面。上端的面板是Designer(设计器),在它之中可以选择表和字段。第二个面板,Criteria(标准),可以用来过滤和排序。第三个面板,SQL,展示由我们的图形化选择所创建的TSQL语句。最后一个面板,Results(结果),将显示这个语句返回的数据。
在第一个例子中,我们将创建一个所有联系人中第一个名字含有Don的电话列表。在Designer面板中选择First Name, Last Name和Phone Number字段。Criteria和SQL面板将根据所做选择自动生成。在Criteria面板中,在First Name行中的过滤字段中输入“=Don”。要执行和测试这个语句,点击红色注释勾选图标。这个语句将看起来如下面的图片所示。
图2
这个语句可以在上面三个面板中的任意一个中进行编辑。例如,在SQL面板中,改变WHERE语句为执行一个LIKE并重新执行。这将返回133行记录
- SELECT TOP (100) PERCENT FirstName, LastName, Phone
- FROM Person.Contact
- WHERE (FirstName LIKE 'Do%')
当这个语句完成时,点击上面菜单条中的保存标签,一个Chose Name for a View对话框将打开。输入名称TestView,然后点击OK。刷新视图列表,然后新的SQL Server视图就出现了。右键单击新的视图将出现一个对话框,类似于一个表对话框,如下所示。
图3
使用TSQL命令创建一个视图是非常直接的。它的语法很简单:
- CREATE VIEW view_name
- AS
- Select_statement
所以第一个例子就是:
- CREATE VIEW TestView
- AS
- SELECT TOP (100) PERCENT FirstName, LastName, Phone
- FROM Person.Contact
- WHERE (FirstName LIKE 'Do%')
在创建一个SQL Server视图时,在SELECT中使用的大多数普通命令都可以使用,例如JOINS和Aliases。这意味着我们使用了一个非常麻烦的语句,将它保存为一个视图,然后只使用它所返回的更简单的表,从而隐藏原来语句的复杂性。在创建视图时有一些命令不能使用。关键字INTO不能像任何对临时表的参照一样使用。此外,ORDER BY不能使用。(在从GUI创建视图时,它将让你指定一个ORDER BY,但是它不会被保存。)所有的Ordering都需要在视图之外的SELECT语句中完成。
从视图中SELECT
右键单击新的视图并选择“SELECT top 1000 rows”。下面的语句将被创建,它的结果将被返回。
- /****** Script for SelectTopNRows command from SSMS ******/
- SELECT TOP 1000 [FirstName]
- ,[LastName]
- ,[Phone]
- FROM [AdventureWorks].[dbo].[TestView]
注意看下从一个视图获得选择结果的语法和从一个表选择项目的语句是多么一致。这是使用视图的一个好处。所有的常用表命令例如GROUP BY和ORDER BY在从一个视图进行选择时都可用。例如,下一个语句是典型的GROUP和COUNT,不过是基于新创建的视图而不是一个表。
SELECT FirstName, COUNT(FirstName) as NbrOfNames
- FROM TestView
- GROUP BY FirstName
- ORDER BY FirstName
图4
从视图UPDATE就像我们可以更新一个表中的数据一样,视图也可以被更新。基于上一个例子,这个语句可以被修改为一个UPDATE,如下所示:
- UPDATE TestView
- SET FirstName = 'Test'
- WHERE FirstName = 'Douglas' AND LastName = 'Baldwin'
只要原来的创建视图的语句没有使用分组命令例如GROUP BY或Distinct,那么这个视图就是可更新的。此外,获取的字段,例如那些使用函数AVG和SUM创建的字段是不能使用的。
要使用Management Studio从一个视图进行更新,在Object Explorer中右键单击这个视图并选择“Edit Top 200 Rows”。这将打开一个可编辑的网格,就像使用表时一样。
图5
总结
使用SQL Server的好处包括限制用户访问底层数据的权限,以及隐藏复杂语句以便可以使用简单的结果集。创建SQL Server视图的语法很简单,而且几乎所有的常用TSQL命令都可用。如果数据要通过一个视图更新或删除,那么在创建这个视图时不能使用聚合和分组语句。
【编辑推荐】