SQL SERVER视图的使用.docx

上传人:b****6 文档编号:7613544 上传时间:2023-01-25 格式:DOCX 页数:9 大小:19.49KB
下载 相关 举报
SQL SERVER视图的使用.docx_第1页
第1页 / 共9页
SQL SERVER视图的使用.docx_第2页
第2页 / 共9页
SQL SERVER视图的使用.docx_第3页
第3页 / 共9页
SQL SERVER视图的使用.docx_第4页
第4页 / 共9页
SQL SERVER视图的使用.docx_第5页
第5页 / 共9页
点击查看更多>>
下载资源
资源描述

SQL SERVER视图的使用.docx

《SQL SERVER视图的使用.docx》由会员分享,可在线阅读,更多相关《SQL SERVER视图的使用.docx(9页珍藏版)》请在冰豆网上搜索。

SQL SERVER视图的使用.docx

SQLSERVER视图的使用

SQL SERVER视图的使用

一、简介

   视图可以被看成是虚拟表或存储查询。

可通过视图访问的数据不作为独特的对象存储在数据库内。

数据库内存储的是SELECT语句。

SELECT语句的结果集构成视图所返回的虚拟表。

用户可以用引用表时所使用的方法,在Transact-SQL语句中通过引用视图名称来使用虚拟表。

使用视图可以实现下列任一或所有功能:

  将用户限定在表中的特定行上。

  例如,只允许雇员看见工作跟踪表内记录其工作的行。

  将用户限定在特定列上。

  例如,对于那些不负责处理工资单的雇员,只允许他们看见雇员表中的姓名列、办公室列、工作电话列和部门列,而不能看见任何包含工资信息或个人信息的列。

  将多个表中的列联接起来,使它们看起来象一个表。

  聚合信息而非提供详细信息。

  例如,显示一个列的和,或列的最大值和最小值。

  通过定义SELECT语句以检索将在视图中显示的数据来创建视图。

SELECT语句引用的数据表称为视图的基表。

在下例中,pubs数据库中的titleview是一个视图,该视图选择三个基表中的数据来显示包含常用数据的虚拟表:

CREATEVIEWtitleview

AS

SELECTtitle,au_ord,au_lname,price,ytd_sales,pub_id

FROMauthorsASa

JOINtitleauthorAStaON(a.au_id=ta.au_id)

JOINtitlesAStON(t.title_id=ta.title_id)

 

之后,可以用引用表时所使用的方法在语句中引用titleview。

SELECT*FROMtitleview

 

  一个视图可以引用另一个视图。

例如,titleview显示的信息对管理人员很有用,但公司通常只在季度或年度财务报表中才公布本年度截止到现在的财政数字。

可以建立一个视图,在其中包含除au_ord和ytd_sales外的所有titleview列。

使用这个新视图,客户可以获得已上市的书籍列表而不会看到财务信息:

CREATEVIEWCust_titleview

AS

SELECTtitle,au_lname,price,pub_id

FROMtitleview

 

  视图可用于在多个数据库或Microsoft?

SQLServer?

2000实例间对数据进行分区。

分区视图可用于在整个服务器组内分布数据库处理。

服务器组具有与服务器聚集相同的性能优点,并可用于支持最大的Web站点或公司数据中心的处理需求。

原始表被细分为多个成员表,每个成员表包含原始表的行子集。

每个成员表可放置在不同服务器的数据库中。

每个服务器也可得到分区视图。

分区视图使用Transact-SQLUNION运算符,将在所有成员表上选择的结果合并为单个结果集,该结果集的行为与整个原始表的复本完全一样。

例如在三个服务器间进行表分区。

在第一个服务器上定义如下的分区视图:

CREATEVIEWPartitionedViewAS

SELECT*

FROMMyDatabase.dbo.PartitionTable1

UNIONALL

SELECT*

FROMServer2.MyDatabase.dbo.PartitionTable2

UNIONALL

SELECT*

FROMServer3.MyDatabase.dbo.PartitionTable3

 

  在其它两个服务器上定义类似的分区视图。

利用这三个视图,三个服务器上任何引用PartitionedView的Transact-SQL语句都将看到与原始表中相同的行为。

似乎每个服务器上都存在原始表的复本一样,而实际上每个表只有一个成员表和分区视图。

有关更多信息,请参见视图使用方案。

  只要所做的修改只影响视图所引用的其中一个基表,就可以更新所有SQLServer版本内的视图(可以对其执行UPDATE、DELETE或INSERT语句)。

--Increasethepricesforpublisher’0736’by10%.

UPDATEtitleview

SETprice=price*1.10

WHEREpub_id=’0736’

GO

 

  SQLServer2000支持可引用视图的更复杂的INSERT、UPDATE和DELETE语句。

可在视图上定义INSTEADOF触发器,指定必须对基表执行的个别更新以支持INSERT、UPDATE或DELETE语句。

另外,分区视图还支持INSERT、UDPATE和DELETE语句修改视图所引用的多个成员表。

  索引视图是SQLServer2000具有的功能,可显著提高复杂视图类型的性能,这些视图类型通常在数据仓库或其它决策支持系统中出现。

  视图的结果集通常不保存在数据库中,因此视图也称为虚拟表。

视图的结果集动态包含在语句逻辑中并在运行时动态生成。

有关更多信息,请参见视图解析。

  复杂的查询(如决策支持系统中的查询)可引用基表中的大量行,并将大量信息聚积在相对较简洁的聚合中,如总和或平均值。

SQLServer2000支持在执行此类复杂查询的视图上创建聚集索引。

当执行CREATEINDEX语句时,视图SELECT的结果集将永久存储在数据库中。

SQL语句此后若引用该视图,响应时间将会显著缩短。

对基本数据的修改将自动反映在视图中。

  SQLServer2000CREATEVIEW语句支持SCHEMABINDING选项,以防止视图所引用的表在视图未被调整的情况下发生改变。

必须为任何创建索引的视图指定SCHEMABINDING。

  例:

创建视图

CreateViewTitleView

AS

SelectID,Title,PostTime,HitsFrom[List]

 

  然后引用SelectTop100*FromTitleView用循环输出数据与直接SelectTop100*From[List]相比速度提高将近30毫秒!

当然我这里只是举例子,一般情况下对单个表没必要去用视图。

二、好处

 l.简化查询语句:

通过视图可以将复杂的查询语句变成很简单。

 2.增加可读性:

由于在视图中可以只显示有用的字段,并且可以使用字段别名,能方便用户浏览查询的结果。

 3.方便程序的维护:

如果用应用程序使用视图来存取数据,那么当数据表的结构发生改变时,只需要更设视图存储的查询语句即可,不需要更改程序。

 4.增加数据的安全性和保密性:

针对不同的用户,可以创建不同的视图,此时的用户只能查看和修改其所能看到的视图中的数据,而真正的数据表中的数据甚至连数据表都是不可见不可访问的,这样可以限制用户浏览和操作的数据内容。

另外视图所引用的表的访问权限与视图的权限设置也是相互不影响的。

注意:

视图是个虚拟的表,其存储的是查询语句而不是数据。

视图中的数据都存储在其引用的数据表中,除非在视图中建立了索引。

三、 创建视图

   创建视图与创建数据表一样,可以使用SQLServerManagementStudio和T-SQL语句两种方法,下面分别介绍这两种方法:

1.在SQLServerManagementStudio中创建视图

在SQLServerManagementStudio中创建视图的方法与创建数据表的方法不同,下面举例说明如何在SQLServerManagementStudio中创建视

图:

(1)启动【SQLServerManagementStudio】,连接到本地默认实例,在【对象资源管理器】窗口里,选择本地数据库实例【数据库】

【Northwind】【视图】。

(2)右击【视图】,在弹出的快捷菜单里选择【新建视图】选项。

(3)出现的如图9.2所示的视图设计对话框,其上有个【添加表】对话框,可以将要引用的表添加到视图设计对话框上,在本例中,添加产品、订单、订单明细、雇员和运货商五个表。

(4)添加完数据表之后,单击【关闭】按钮,返回到如图9.3所示的【视图设计】窗口。

如果还要添加新的数据表,可以右击【关系图窗格】的空白处,在弹出的快捷菜单里选择【添加表】选项,则会弹出如图9.2中所示的【添加表】对话框,然后继续为视图添加引用表或视图。

如果要移除已经添加的数据表或视图,可以右击在【关系图窗格】里选择要移除的数据表或视图,在弹出的快捷菜单里选择【移除】选项,或选中

要移除的数据表或视图后,直接按【Delete】按钮移除。

(5)在【关系图窗格】里,可以建立表与表之间的JOIN…ON关系,如【产品】表的“产品ID”与【订单明细】表中的“产品ID”相等,那么只要将【产品】表中的“产品ID”字段拖拽到【订单明细】表中的“产品ID”字段上即可。

此时两个表之间将会有一根线连着的。

(6)在【关系图窗格】里选择数据表字段前的复选框,可以设置视图要输出的字段,同样,在【条件窗格】里也可设置要输出的字段。

(7)在【条件窗格】里还可以设置要过滤的查询条件。

(8)设置完后的SQL语句,会显示在【SQL窗格】里,这个Select语句也就是视图所要存储的查询语句。

(9)所有查询条件设置完毕之后,单击【执行SQL】按钮,试运行Select语句是否正确。

(10)在一切测试都正常之后,单击【保存】按钮,在弹出的对话框里输入视图名称,再单击【确定】按钮完成操作。

2.用Createview创建视图

2.1基本语法

用T-SQL的createview语句可以创建视图,其语法为:

CREATEVIEW[schema_name.]view_name                  --架构名.视图名

   [(column[,...n])]                             --列名

[WITH[,...n]]

ASselect_statement[;]                                --搜索语句

[WITHCHECKOPTION]          --强制修改语句都必须符合在select_statement中设置的条件

:

:

=

{

   [ENCRYPTION]                                         --加密

   [SCHEMABINDING]                                     --绑定架构

   [VIEW_METADATA]    }                                --返回有关视图的元数据信息

2.2参数说明

Createview的参数有:

lschema_name:

视图所属架构名

 view_name:

视图名

 column:

视图中所使用的列名,一般只有列是从算术表达式、函数或常量派生出来的或者列的指定名称不同于来源列的名称时,才需要使用。

 select_statement:

搜索语句。

WITHCHECKOPTION:

强制针对视图执行的所有数据修改语句都必须符合在select_statement中设置的条件。

 ENCRYPTION:

加密视图。

 SCHEMABINDING:

将视图绑定到基础表的架构。

 VIEW_METADATA:

指定为引用视图的查询请求浏览模式的元数据时,SQLServer实例将向DB-Library、ODBC和OLEDBAPI返回有关视图

的元数据信息,而不返回基表的元数据信息。

2.3简单用法

例一、创建一个视图,用于查看产品、类别和供应商,其代码如下:

--创建视图

CREATEVIEWview_例一

        AS

        SELECT产品.产品ID,产品.产品名称,类别.类别名称,供应商.公司名称

                  FROM产品

                  JOIN类别ON产品.类别ID=类别.类别ID

                  JOIN供应商ON产品.供应商ID=供应商.供应商ID

GO<

四、SQLSERVER2000与SQLServer2008在代码上的一个区别

   2000的别名与字段名分开,中间用一个AS,而2008的格式为:

别名AS字段名

五、一个复杂的视图举例(摘自某应用系统,以下代码为一个视图):

SELECT    bing_li.hos_id+y_z_b.daima,y_z_b.history_date,y_z_b.yphzl,y_z_b.yb_xmbm,'.','.','.',y_z_b.p_dw,y_z_b.hz_sl,y_z_b.dj,y_z_b.hz_je,'西药',y_z_b.bq,y_z_b.ch,y_z_b.ys_name

FROM        y_z_b,bing_li

WHERE    y_z_b.daima=bing_li.daimaANDy_z_b.zy_bz='1'ANDy_z_b.yz_jj='1'ANDy_z_b.feiyong_lb='0'ANDy_z_b.yplb='1'ANDbing_li.fylb='1'

UNIONALL

SELECT    bing_li.hos_id+y_z_b.daima,y_z_b.history_date,y_z_b.yphzl,y_z_b.yb_xmbm,'.','.','.',y_z_b.p_dw,y_z_b.hz_sl,y_z_b.dj,y_z_b.hz_je,'中成药',y_z_b.bq,y_z_b.ch,y_z_b.ys_name

FROM        y_z_b,bing_li

WHERE    y_z_b.daima=bing_li.daimaANDy_z_b.zy_bz='1'ANDy_z_b.yz_jj='1'ANDy_z_b.feiyong_lb='0'ANDyplb='2'ANDbing_li.fylb='1'

UNIONALL

SELECT    bing_li.hos_id+y_z_b.daima,y_z_b.history_date,y_z_b.yphzl,y_z_b.yb_xmbm,'.','.','.',y_z_b.p_dw,y_z_b.hz_sl,y_z_b.dj,y_z_b.hz_je,'中药',y_z_b.bq,y_z_b.ch,y_z_b.ys_name

FROM        y_z_b,bing_li

WHERE    y_z_b.daima=bing_li.daimaANDy_z_b.zy_bz='1'ANDy_z_b.yz_jj='1'ANDy_z_b.feiyong_lb='0'ANDyplb='3'ANDbing_li.fylb='1'

UNIONALL

SELECT    bing_li.hos_id+y_z_b.daima,y_z_b.history_date,y_z_b.yphzl,y_z_b.yb_xmbm,'.','.','.',y_z_b.p_dw,y_z_b.hz_sl,y_z_b.dj,y_z_b.hz_je,'住院',y_z_b.bq,y_z_b.ch,y_z_b.ys_name

FROM        y_z_b,bing_li

WHERE    y_z_b.daima=bing_li.daimaANDy_z_b.zy_bz='1'ANDy_z_b.yz_jj='1'ANDy_z_b.feiyong_lb='1'ANDyplb='4'ANDbing_li.fylb='1'

UNIONALL

SELECT    bing_li.hos_id+y_z_b.daima,y_z_b.history_date,y_z_b.yphzl,y_z_b.yb_xmbm,'.','.','.',y_z_b.p_dw,y_z_b.hz_sl,y_z_b.dj,y_z_b.hz_je,'冷暖',y_z_b.bq,y_z_b.ch,y_z_b.ys_name

FROM        y_z_b,bing_li

WHERE    y_z_b.daima=bing_li.daimaANDy_z_b.zy_bz='1'ANDy_z_b.yz_jj='1'ANDy_z_b.feiyong_lb='1'ANDyplb='5'ANDbing_li.fylb='1'

UNIONALL

SELECT    bing_li.hos_id+y_z_b.daima,y_z_b.history_date,y_z_b.yphzl,y_z_b.yb_xmbm,'.','.','.',y_z_b.p_dw,y_z_b.hz_sl,y_z_b.dj,y_z_b.hz_je,'治疗',y_z_b.bq,y_z_b.ch,y_z_b.ys_name

FROM        y_z_b,bing_li

WHERE    y_z_b.daima=bing_li.daimaANDy_z_b.zy_bz='1'ANDy_z_b.yz_jj='1'ANDy_z_b.feiyong_lb='1'ANDyplb='6'ANDbing_li.fylb='1'

UNIONALL

SELECT    bing_li.hos_id+y_z_b.daima,y_z_b.history_date,y_z_b.yphzl,y_z_b.yb_xmbm,'.','.','.',y_z_b.p_dw,y_z_b.hz_sl,y_z_b.dj,y_z_b.hz_je,'检查',y_z_b.bq,y_z_b.ch,y_z_b.ys_name

FROM        y_z_b,bing_li

WHERE    y_z_b.daima=bing_li.daimaANDy_z_b.zy_bz='1'ANDy_z_b.yz_jj='1'ANDy_z_b.feiyong_lb='1'ANDyplb='7'ANDbing_li.fylb='1'

UNIONALL

SELECT    bing_li.hos_id+y_z_b.daima,y_z_b.history_date,y_z_b.yphzl,y_z_b.yb_xmbm,'.','.','.',y_z_b.p_dw,y_z_b.hz_sl,y_z_b.dj,y_z_b.hz_je,'化验',y_z_b.bq,y_z_b.ch,y_z_b.ys_name

FROM        y_z_b,bing_li

WHERE    y_z_b.daima=bing_li.daimaANDy_z_b.zy_bz='1'ANDy_z_b.yz_jj='1'ANDy_z_b.feiyong_lb='1'ANDyplb='8'ANDbing_li.fylb='1'

UNIONALL

SELECT    bing_li.hos_id+y_z_b.daima,y_z_b.history_date,y_z_b.yphzl,y_z_b.yb_xmbm,'.','.','.',y_z_b.p_dw,y_z_b.hz_sl,y_z_b.dj,y_z_b.hz_je,'接生',y_z_b.bq,y_z_b.ch,y_z_b.ys_name

FROM        y_z_b,bing_li

WHERE    y_z_b.daima=bing_li.daimaANDy_z_b.zy_bz='1'ANDy_z_b.yz_jj='1'ANDy_z_b.feiyong_lb='1'ANDyplb='9'ANDbing_li.fylb='1'

UNIONALL

SELECT    bing_li.hos_id+y_z_b.daima,y_z_b.history_date,y_z_b.yphzl,y_z_b.yb_xmbm,'.','.','.',y_z_b.p_dw,y_z_b.hz_sl,y_z_b.dj,y_z_b.hz_je,'婴儿',y_z_b.bq,y_z_b.ch,y_z_b.ys_name

FROM        y_z_b,bing_li

WHERE    y_z_b.daima=bing_li.daimaANDy_z_b.zy_bz='1'ANDy_z_b.yz_jj='1'ANDy_z_b.feiyong_lb='1'ANDyplb='10'ANDbing_li.fylb='1'

UNIONALL

SELECT    bing_li.hos_id+y_z_b.daima,y_z_b.history_date,y_z_b.yphzl,y_z_b.yb_xmbm,'.','.','.',y_z_b.p_dw,y_z_b.hz_sl,y_z_b.dj,y_z_b.hz_je,'医疗',y_z_b.bq,y_z_b.ch,y_z_b.ys_name

FROM        y_z_b,bing_li

WHERE    y_z_b.daima=bing_li.daimaANDy_z_b.zy_bz='1'ANDy_z_b.yz_jj='1'ANDy_z_b.feiyong_lb='1'ANDyplb='11'ANDbing_li.fylb='1'

UNIONALL

SELECT    bing_li.hos_id+y_z_b.daima,y_z_b.history_date,y_z_b.yphzl,y_z_b.yb_xmbm,'.','.','.',y_z_b.p_dw,y_z_b.hz_sl,y_z_b.dj,y_z_b.hz_je,'放射',y_z_b.bq,y_z_b.ch,y_z_b.ys_name

FROM        y_z_b,bing_li

WHERE    y_z_b.daima=bing_li.daimaANDy_z_b.zy_bz='1'A

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 经管营销 > 经济市场

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1