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
正在阅读:
Microsoft SQL Server 2005技术内幕_第5章-视图 Views05-17
医院院内感染管理相关制度目录02-03
实验四静态路由配置实验报告10-23
幼儿园欢送会祝词02-18
创业板退市方案修改完善08-12
SPSS问卷数据的基本操作练习样例01-24
沉毅练达_厚积薄发_青年浮躁心理思考06-07
励志散文随笔02-19
优秀教师个人警示教育心得感悟范文四篇03-24
盐城市名校长候选人公示01-21
- 教学能力大赛决赛获奖-教学实施报告-(完整图文版)
- 互联网+数据中心行业分析报告
- 2017上海杨浦区高三一模数学试题及答案
- 招商部差旅接待管理制度(4-25)
- 学生游玩安全注意事项
- 学生信息管理系统(文档模板供参考)
- 叉车门架有限元分析及系统设计
- 2014帮助残疾人志愿者服务情况记录
- 叶绿体中色素的提取和分离实验
- 中国食物成分表2020年最新权威完整改进版
- 推动国土资源领域生态文明建设
- 给水管道冲洗和消毒记录
- 计算机软件专业自我评价
- 高中数学必修1-5知识点归纳
- 2018-2022年中国第五代移动通信技术(5G)产业深度分析及发展前景研究报告发展趋势(目录)
- 生产车间巡查制度
- 2018版中国光热发电行业深度研究报告目录
- (通用)2019年中考数学总复习 第一章 第四节 数的开方与二次根式课件
- 2017_2018学年高中语文第二单元第4课说数课件粤教版
- 上市新药Lumateperone(卢美哌隆)合成检索总结报告
- 视图
- 内幕
- Microsoft
- Server
- Views
- 技术
- 2005
- SQL
- 中国西式小家电行业市场竞争战略分析及发展前景展望研究报告2016-2021年
- 药品说明书和标签管理规定
- 家具设计风格调研报告最终版
- 小型无人机飞控计算机设计
- 2013山西省公务员考试面试资料汇总
- 中华人民共和国民事诉讼法2012修订前后对照表
- 变电站自动化发展综述
- 初三化学物质的组成练习题
- 震撼全球66亿人的健康大发现:肉蛋奶是人类第一杀手
- 中医妇女保健方案
- 浙江省2002年4月高等教育自学考试中医基础理论14
- 广州金发科技股份有限公司第二届董事会第六次会议决议公告
- 九年级历史期末考试试卷分析
- 合肥学院红十字会工作计划
- 矿山地质IB姚玉增
- WDSC-JX-007 工厂停电应急预案
- 2014年银监会监管统计信息发布日程表
- “十三五”重点项目-甘蔗种植项目可行性研究报告
- 犬髌骨脱位手术治疗的探讨_夏新萌
- 大学物理——韩永胜——08第六章机械振动