sqlserver视图的使用

sqlserver视图的使用

ID:33843059

大小:58.50 KB

页数:11页

时间:2019-03-01

sqlserver视图的使用_第1页
sqlserver视图的使用_第2页
sqlserver视图的使用_第3页
sqlserver视图的使用_第4页
sqlserver视图的使用_第5页
资源描述:

《sqlserver视图的使用》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、SQL SERVER视图的使用一、简介   视图可以被看成是虚拟表或存储查询。可通过视图访问的数据不作为独特的对象存储在数据库内。数据库内存储的是SELECT语句。SELECT语句的结果集构成视图所返回的虚拟表。用户可以用引用表时所使用的方法,在Transact-SQL语句中通过引用视图名称来使用虚拟表。使用视图可以实现下列任一或所有功能:  将用户限定在表中的特定行上。  例如,只允许雇员看见工作跟踪表内记录其工作的行。  将用户限定在特定列上。  例如,对于那些不负责处理工资单的雇员,只允许他们看见雇员表中的姓名列、办公室列、工作电话列和部门列,而不能看见任何包含工资信息或个人信

2、息的列。  将多个表中的列联接起来,使它们看起来象一个表。  聚合信息而非提供详细信息。  例如,显示一个列的和,或列的最大值和最小值。  通过定义SELECT语句以检索将在视图中显示的数据来创建视图。SELECT语句引用的数据表称为视图的基表。在下例中,pubs数据库中的titleview是一个视图,该视图选择三个基表中的数据来显示包含常用数据的虚拟表:CREATEVIEWtitleviewASSELECTtitle,au_ord,au_lname,price,ytd_sales,pub_idFROMauthorsASaJOINtitleauthorAStaON(a.au_id=t

3、a.au_id)JOINtitlesAStON(t.title_id=ta.title_id) 之后,可以用引用表时所使用的方法在语句中引用titleview。SELECT*FROMtitleview   一个视图可以引用另一个视图。例如,titleview显示的信息对管理人员很有用,但公司通常只在季度或年度财务报表中才公布本年度截止到现在的财政数字。可以建立一个视图,在其中包含除au_ord和ytd_sales外的所有titleview列。使用这个新视图,客户可以获得已上市的书籍列表而不会看到财务信息:CREATEVIEWCust_titleviewASSELECTtitle,au

4、_lname,price,pub_idFROMtitleview   视图可用于在多个数据库或Microsoft?SQLServer?2000实例间对数据进行分区。分区视图可用于在整个服务器组内分布数据库处理。服务器组具有与服务器聚集相同的性能优点,并可用于支持最大的Web站点或公司数据中心的处理需求。原始表被细分为多个成员表,每个成员表包含原始表的行子集。每个成员表可放置在不同服务器的数据库中。每个服务器也可得到分区视图。分区视图使用Transact-SQLUNION运算符,将在所有成员表上选择的结果合并为单个结果集,该结果集的行为与整个原始表的复本完全一样。例如在三个服务器间进行

5、表分区。在第一个服务器上定义如下的分区视图:CREATEVIEWPartitionedViewASSELECT*FROMMyDatabase.dbo.PartitionTable1UNIONALLSELECT*FROMServer2.MyDatabase.dbo.PartitionTable2UNIONALLSELECT*FROMServer3.MyDatabase.dbo.PartitionTable3   在其它两个服务器上定义类似的分区视图。利用这三个视图,三个服务器上任何引用PartitionedView的Transact-SQL语句都将看到与原始表中相同的行为。似乎每个服务

6、器上都存在原始表的复本一样,而实际上每个表只有一个成员表和分区视图。有关更多信息,请参见视图使用方案。  只要所做的修改只影响视图所引用的其中一个基表,就可以更新所有SQLServer版本内的视图(可以对其执行UPDATE、DELETE或INSERT语句)。--Increasethepricesforpublisher’0736’by10%.UPDATEtitleviewSETprice=price*1.10WHEREpub_id=’0736’GO   SQLServer2000支持可引用视图的更复杂的INSERT、UPDATE和DELETE语句。可在视图上定义INSTEADOF触发

7、器,指定必须对基表执行的个别更新以支持INSERT、UPDATE或DELETE语句。另外,分区视图还支持INSERT、UDPATE和DELETE语句修改视图所引用的多个成员表。  索引视图是SQLServer2000具有的功能,可显著提高复杂视图类型的性能,这些视图类型通常在数据仓库或其它决策支持系统中出现。  视图的结果集通常不保存在数据库中,因此视图也称为虚拟表。视图的结果集动态包含在语句逻辑中并在运行时动态生成。有关更多信息,请参见视图解析。  复杂

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。