IT技术网www.itjs.cn

当前位置:首页 > 数据库 > SQl Server > SQL Server视图操作原理透析(1)

SQL Server视图操作原理透析(1)

发布时间:2015-10-20 00:00 来源:未知

为什么使用视图

视图是一个便利的方法,它只给用户对一个表的部分访问权限。视图可以限制将返回的记录以及可用的字段。所以授权用户对这个视图的访问权限而不是这个表本身来限制他们的访问权限。视图还是一个用于隐藏复杂语句和只显示给终端用户一个简单的单一表结果集的便利方法。

创建一个视图

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。这将出现如下所示的图形设计器。

SQL Server视图操作原理透析(1) 

这个语句可以在上面三个面板中的任意一个中进行编辑。例如,在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视图就出现了。右键单击新的视图将出现一个对话框,类似于一个表对话框,如下所示。

SQL Server视图操作原理透析(1) 

图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”。这将打开一个可编辑的网格,就像使用表时一样。

SQL Server视图操作原理透析(1) 

为什么使用视图

视图是一个便利的方法,它只给用户对一个表的部分访问权限。视图可以限制将返回的记录以及可用的字段。所以授权用户对这个视图的访问权限而不是这个表本身来限制他们的访问权限。视图还是一个用于隐藏复杂语句和只显示给终端用户一个简单的单一表结果集的便利方法。

创建一个视图

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。这将出现如下所示的图形设计器。

SQL Server视图操作原理透析(1) 

图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”。这将打开一个可编辑的网格,就像使用表时一样。

SQL Server视图操作原理透析(1) 
图5

总结

使用SQL Server的好处包括限制用户访问底层数据的权限,以及隐藏复杂语句以便可以使用简单的结果集。创建SQL Server视图的语法很简单,而且几乎所有的常用TSQL命令都可用。假如数据要通过一个视图更新或删除,那么在创建这个视图时不能使用聚合和分组语句。