SQL Server视图操作原理透析

为什么使用视图

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

创建一个视图

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

#p#

这个语句可以在上面三个面板中的任意一个中进行编辑。例如,在SQL面板中,改变WHERE语句为执行一个LIKE并重新执行。这将返回133行记录

  1. SELECT TOP (100) PERCENT FirstName, LastName, Phone   
  2. FROM Person.Contact  
  3. WHERE (FirstName LIKE 'Do%')  

当这个语句完成时,点击上面菜单条中的保存标签,一个Chose Name for a View对话框将打开。输入名称TestView,然后点击OK。刷新视图列表,然后新的SQL Server视图就出现了。右键单击新的视图将出现一个对话框,类似于一个表对话框,如下所示。

 
图3

使用TSQL命令创建一个视图是非常直接的。它的语法很简单:

  1. CREATE VIEW view_name   
  2. AS 
  3. Select_statement  

所以第一个例子就是:

  1. CREATE VIEW TestView   
  2. AS 
  3. SELECT TOP (100) PERCENT FirstName, LastName, Phone  
  4. FROM Person.Contact  
  5. WHERE (FirstName LIKE 'Do%')  

在创建一个SQL Server视图时,在SELECT中使用的大多数普通命令都可以使用,例如JOINS和Aliases。这意味着我们使用了一个非常麻烦的语句,将它保存为一个视图,然后只使用它所返回的更简单的表,从而隐藏原来语句的复杂性。在创建视图时有一些命令不能使用。关键字INTO不能像任何对临时表的参照一样使用。此外,ORDER BY不能使用。(在从GUI创建视图时,它将让你指定一个ORDER BY,但是它不会被保存。)所有的Ordering都需要在视图之外的SELECT语句中完成。

从视图中SELECT

右键单击新的视图并选择“SELECT top 1000 rows”。下面的语句将被创建,它的结果将被返回。

  1.  /****** Script for SelectTopNRows command from SSMS ******/   
  2. SELECT TOP 1000 [FirstName]  
  3. ,[LastName]  
  4. ,[Phone]  
  5. FROM [AdventureWorks].[dbo].[TestView] 

注意看下从一个视图获得选择结果的语法和从一个表选择项目的语句是多么一致。这是使用视图的一个好处。所有的常用表命令例如GROUP BY和ORDER BY在从一个视图进行选择时都可用。例如,下一个语句是典型的GROUP和COUNT,不过是基于新创建的视图而不是一个表。

SELECT FirstName, COUNT(FirstName) as NbrOfNames   
  1. FROM TestView  
  2. GROUP BY FirstName  
  3. ORDER BY FirstName 

图4

从视图UPDATE就像我们可以更新一个表中的数据一样,视图也可以被更新。基于上一个例子,这个语句可以被修改为一个UPDATE,如下所示:

  1. UPDATE TestView   
  2. SET FirstName = 'Test' 
  3. 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命令都可用。如果数据要通过一个视图更新或删除,那么在创建这个视图时不能使用聚合和分组语句。

【编辑推荐】

  1. SQL Server 2008中的创建格式化日期(1)
  2. 在T-SQL中使用临时表的注意事项
  3. T-SQL实用例句
  4. SQL Server 2005中的T-SQL
  5. SQL Server 2005:数据类型最大值

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/243078.html<

(0)
运维的头像运维
上一篇2025-04-25 02:38
下一篇 2025-04-25 02:40

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注