Microsoft SQL Server 2005技术内幕_第5章-视图 Views

更新时间:2023-05-17 14:01:01 阅读量: 实用文档 文档下载

说明:文章内容仅供预览,部分内容可能不全。下载后的文档,内容与下面显示的完全一致。下载之前请确认下面内容是否您想要的,是否完整无缺。

Microsoft SQL Server 2005技术内幕_第5章-视图 Views

Microsoft SQL Server 2005技术内幕:T-SQL程序设计

第5章 视图 Views 本章内容:

5.1 什么是视图? 181 5.2 视图中的ORDER BY 183 5.3 刷新视图 187 5.4 模块化方法 189 5.5 更新视图 198 5.6 视图选项 202

5.7 索引视图(Indexed View) 206 5.8 结论 211

本章首先简单地描述视图及其用法。随后,我将讨论使用视图时的一些细节。此外,我还会介绍如何利用视图简化查询以及利用索引视图提高数据库的性能。

5.1 什么是视图?

视图是一个命名的虚拟表(virtual table),它由一个查询来定义,可以当作表使用。与持久表(permanent table)不同的是,视图中的数据没有物理表现形式,除非你为其创建索引。当你在一个未建索引的视图执行查询时,SQL Server实际访问的是基础表(underlying table)。除非特别说明,本章的讨论都是指的未建索引的视图。

如果你要创建一个视图,为其指定一个名称和一个查询即可。Microsoft SQL Server只保存视图的元数据(metadata),用于描述这个对象,以及它所包含的列、安全、依赖等。当你查询视图时,无论是获取数据还是修改数据,查询处理器(query processor)都会用视图定义代替视图引用。也就是说,查询处理器展开视图定义并生成访问基对象(underlying objects)的执行计划。

视图在数据库中发挥着重要的作用。视图的重要用途之一便是被用作一个抽象装置(abstraction mechanism)。例如,在适当时利用视图你可以很容易地为基础数据提供或多或少的规范化映像(normalized picture),这样就不用更改实际数据的规范化(normalization)。通过应用模块化的方法(逐步解决复杂问题),可以简化解决方案。可以利用视图访问经过筛选和处理的数据,而不是直接对基表(base table)进行操作(让视图的架构和基对象的架构相同),可以把视图作为一个安全层(security layer)(在一定程度上)。

如果在视图上创建索引,它在提高性能方面也发挥着重要作用。在视图上创建聚集索引(clustered index)会让它的数据真正地保存在磁盘上,而不再是虚拟的数据。我会在本章专门用一节介绍索引视图。现在,我们先来关注没有索引的视图,它们通常没有特定的性能影响,包括消极的或积极的。

1

Microsoft SQL Server 2005技术内幕_第5章-视图 Views

该视图包含发生过订单的消费者。

注意:如果你尝试在SQL Server 2000中运行这段代码,会因为CREATE VIEW语句末尾的分号而导致失败。要在SQL Server 2000中创建该视图,删除分号即可。分号在ANSI中是必须的,而在以前T-SQL中不必使用分号。SQL Server 2005 只在某些情况下要求你必须使用分号,例如在定义CTE的WITH子句前面使用分号以避免混淆(因为WITH子句还有其他用途)。除此之外,分号的使用是可选的。然而,因为分号是ANSI所必须的,慢慢习惯使用分号也许是个好主意。

该视图的查询使用EXISTS谓词返回在Orders表中至少有一个订单的消费者。

提示:顺便提一下,通常在SELECT中使用*不是一个好习惯,但你可以在EXISTS谓词中放心使用。优化器知道EXISTS谓词不需要引用行的特定属性。它只关心行是否存在。因此,它会完全忽略SELECT列表。通过检查这些查询的执行计划你可以得出这个结论,你会注意到如果被筛选的列(在前面的例子

2

Microsoft SQL Server 2005技术内幕_第5章-视图 Views

代码运行时不产生错误,这就说明了SQL Server并没有计算表达式。如果SQL Server计算该表达式,你会收到一个错误。

下面这一节将更详细地研究视图的各种特性,先解释视图的查询中没有TOP或FOR XML说明符时禁止使用ORDER BY子句的原因。

注意,该错误并不是说ORDER BY完全被禁止,而是说只有在两种情况下可以使用该子句即指定TOP或FOR XML。TOP和FOR XML都是T-SQL的扩展,不是标准的SQL元素。TOP和ORDER BY以及ORDER BY和FOR XML是结果集规范(result set specification)的一部分,但单独的ORDER BY并不是。因此,TOP和ORDER BY以及ORDER BY和FOR XML可以出现在视图定义中,而单独的

3

Microsoft SQL Server 2005技术内幕_第5章-视图 Views

注意 上面的代码假定你正在使用SQL Server 2005。因此,它使用分号来结束ALTER VIEW语句,并在TOP选项中使用括号。如果你要在SQL Server 2000中测试这段代码,需要删除括号和分号。 视图中的ORDER BY子句意味着什么呢?它的意义不是很明确,因为TOP选项不是ANSI的标准语句。但如果你从集合的角度思考一下,就会认为ORDER BY子句没有什么意义了,因为你已经选择了所有符合筛选表达式(filter expression)的行。查询视图时,SQL Server不保证输出的顺序,除非在外部查询包含ORDER BY子句。SQL Server 2005联机丛书有一段对该行为的描述:“在视图、内联函数、派生表或子查询的定义中使用 ORDER BY 时,子句只用于确定 TOP 子句返回的行。ORDER BY 不保证

4

Microsoft SQL Server 2005技术内幕_第5章-视图 Views

5

Microsoft SQL Server 2005技术内幕_第5章-视图 Views

6

Microsoft SQL Server 2005技术内幕_第5章-视图 Views

7

Microsoft SQL Server 2005技术内幕_第5章-视图 Views

5.4 模块化方法

视图可用于以模块化方法开发解决方案。问题的每一步都用一个查询解决,并根据查询定义视图。这样一次只关注其中的某一步,从而简化了解决方案。

8

Microsoft SQL Server 2005技术内幕_第5章-视图 Views

该表每个月占一行,其中包含销售数量(qty列)和月份(mnth列)。要注意我使用了DATETIME数据类型存储月份以支持日相关的计算。尽管我只关心其中的年份和月份,我也必须在日部分指定一些值。所以我把每个月的第一天作为日部分,并假设子夜为默认时间。当你需要显示日期时,你总是可以

9

Microsoft SQL Server 2005技术内幕_第5章-视图 Views

还记得吗?在SQL Server 2000中不能用分号结束CREATE VIEW语句,也不能用圆括号作为TOP的输入。VSgn视图的内容如表5-6所示。 有5-6 VSgn 的内容

10

Microsoft SQL Server 2005技术内幕_第5章-视图 Views

11

Microsoft SQL Server 2005技术内幕_第5章-视图 Views

12

Microsoft SQL Server 2005技术内幕_第5章-视图 Views

13

Microsoft SQL Server 2005技术内幕_第5章-视图 Views

14

Microsoft SQL Server 2005技术内幕_第5章-视图 Views

计算分组因子的逻辑有点复杂。根据sgn(趋势)分区并按mnth的顺序计算出行号(rn)。它的意思是,对于每一种趋势,你可以有多个连续的组,它们之间会有间断。试着思考一下在某个趋势中随着rn的递增,mnth值如何变化。只要它们还位于同一个连续组中,它们都会以1为单位递增。一旦出现间断,mnth的递增量会大于1,而rn的递增%

5.5 更新视图

视图是一个虚拟的表,当你查询视图时,SQL Server会展开视图的select语句并对基础表执行查询。视图不仅可以作为SELECT查询的目标,它也可以作为修改语句的目标。当你修改视图时,SQL Server将修改基础表。这时的视图就像是一个代理或媒介。当然,如果不允许直接修改基础表,只允许修改视

15

Microsoft SQL Server 2005技术内幕_第5章-视图 Views

16

Microsoft SQL Server 2005技术内幕_第5章-视图 Views

17

Microsoft SQL Server 2005技术内幕_第5章-视图 Views

注意其中消费者的属性,比如公司名称(cname),每个订单都有重复。

假设用户拥有该视图的UPDATE权限,他想把订单ID(oid)等于1001的公司名称修改为 Cust 42 。该用户会提交下面的更新。

18

Microsoft SQL Server 2005技术内幕_第5章-视图 Views

19

Microsoft SQL Server 2005技术内幕_第5章-视图 Views

20

Microsoft SQL Server 2005技术内幕_第5章-视图 Views

21

本文来源:https://www.bwwdw.com/article/ce04.html

Top