ImageVerifierCode 换一换
格式:DOCX , 页数:9 ,大小:19.49KB ,
资源ID:7613544      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/7613544.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(SQL SERVER视图的使用.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

SQL SERVER视图的使用.docx

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

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

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

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

5、,该结果集的行为与整个原始表的复本完全一样。例如在三个服务器间进行表分区。在第一个服务器上定义如下的分区视图:CREATE VIEW PartitionedView ASSELECT *FROM MyDatabase.dbo.PartitionTable1UNION ALLSELECT *FROM Server2.MyDatabase.dbo.PartitionTable2UNION ALLSELECT *FROM Server3.MyDatabase.dbo.PartitionTable3在其它两个服务器上定义类似的分区视图。利用这三个视图,三个服务器上任何引用 PartitionedVie

6、w 的 Transact-SQL 语句都将看到与原始表中相同的行为。似乎每个服务器上都存在原始表的复本一样,而实际上每个表只有一个成员表和分区视图。有关更多信息,请参见视图使用方案。只要所做的修改只影响视图所引用的其中一个基表,就可以更新所有 SQL Server 版本内的视图(可以对其执行 UPDATE、DELETE 或 INSERT 语句)。- Increase the prices for publisher 0736 by 10%.UPDATE titleviewSET price = price * 1.10WHERE pub_id = 0736GOSQL Server 2000 支

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

8、决策支持系统中的查询)可引用基表中的大量行,并将大量信息聚积在相对较简洁的聚合中,如总和或平均值。SQL Server 2000 支持在执行此类复杂查询的视图上创建聚集索引。当执行 CREATE INDEX 语句时,视图 SELECT 的结果集将永久存储在数据库中。SQL 语句此后若引用该视图,响应时间将会显著缩短。对基本数据的修改将自动反映在视图中。SQL Server 2000 CREATE VIEW 语句支持 SCHEMABINDING 选项,以防止视图所引用的表在视图未被调整的情况下发生改变。必须为任何创建索引的视图指定 SCHEMABINDING。例:创建视图Create View

9、TitleViewASSelect ID,Title,PostTime,Hits From List然后引用Select Top 100 * From TitleView 用循环输出数据与直接Select Top 100 * From List相比速度提高将近30毫秒!当然我这里只是举例子,一般情况下对单个表没必要去用视图。二、好处l. 简化查询语句:通过视图可以将复杂的查询语句变成很简单。2. 增加可读性:由于在视图中可以只显示有用的字段,并且可以使用字段别名,能方便用户浏览查询的结果。3. 方便程序的维护:如果用应用程序使用视图来存取数据,那么当数据表的结构发生改变时,只需要更设视图存储的

10、查询语句即可,不需要更改程序。4. 增加数据的安全性和保密性:针对不同的用户,可以创建不同的视图,此时的用户只能查看和修改其所能看到的视图中的数据,而真正的数据表中的数据甚至连数据表都是不可见不可访问的,这样可以限制用户浏览和操作的数据内容。另外视图所引用的表的访问权限与视图的权限设置也是相互不影响的。注意:视图是个虚拟的表,其存储的是查询语句而不是数据。视图中的数据都存储在其引用的数据表中,除非在视图中建立了索引。三、创建视图 创建视图与创建数据表一样,可以使用SQL Server Management Studio和T-SQL语句两种方法,下面分别介绍这两种方法:1. 在SQL Serve

11、r Management Studio中创建视图在SQL Server Management Studio中创建视图的方法与创建数据表的方法不同,下面举例说明如何在SQL Server Management Studio中创建视图:(1)启动【SQL Server Management Studio】,连接到本地默认实例,在【对象资源管理器】窗口里,选择本地数据库实例【数据库】【Northwind】【视图】。(2)右击【视图】,在弹出的快捷菜单里选择【新建视图】选项。(3)出现的如图9.2所示的视图设计对话框,其上有个【添加表】对话框,可以将要引用的表添加到视图设计对话框上,在本例中,添加产品

12、、订单、订单明细、雇员和运货商五个表。(4)添加完数据表之后,单击【关闭】按钮,返回到如图9.3所示的【视图设计】窗口。如果还要添加新的数据表,可以右击【关系图窗格】的空白处,在弹出的快捷菜单里选择【添加表】选项,则会弹出如图9.2中所示的【添加表】对话框,然后继续为视图添加引用表或视图。如果要移除已经添加的数据表或视图,可以右击在【关系图窗格】里选择要移除的数据表或视图,在弹出的快捷菜单里选择【移除】选项,或选中要移除的数据表或视图后,直接按【Delete】按钮移除。(5)在【关系图窗格】里,可以建立表与表之间的JOINON关系,如【产品】表的“产品ID”与【订单明细】表中的“产品ID”相等

13、,那么只要将【产品】表中的“产品ID”字段拖拽到【订单明细】表中的“产品ID”字段上即可。此时两个表之间将会有一根线连着的。(6)在【关系图窗格】里选择数据表字段前的复选框,可以设置视图要输出的字段,同样,在【条件窗格】里也可设置要输出的字段。(7)在【条件窗格】里还可以设置要过滤的查询条件。(8)设置完后的SQL语句,会显示在【SQL窗格】里,这个Select语句也就是视图所要存储的查询语句。(9)所有查询条件设置完毕之后,单击【执行SQL】按钮,试运行Select语句是否正确。(10)在一切测试都正常之后,单击【保存】按钮,在弹出的对话框里输入视图名称,再单击【确定】按钮完成操作。2. 用

14、Create view创建视图2.1 基本语法用T-SQL的create view语句可以创建视图,其语法为:CREATE VIEW schema_name . view_name -架构名.视图名 (column ,.n ) -列名 WITH ,.n AS select_statement ; -搜索语句 WITH CHECK OPTION -强制修改语句都必须符合在select_ statement中设置的条件 := ENCRYPTION -加密 SCHEMABINDING -绑定架构 VIEW_METADATA -返回有关视图的元数据信息2.2 参数说明Create view的参数有:l

15、 schema_name:视图所属架构名view_name:视图名column:视图中所使用的列名,一般只有列是从算术表达式、函数或常量派生出来的或者列的指定名称不同于来源列的名称时,才需要使用。select_statement:搜索语句。WITH CHECK OPTION:强制针对视图执行的所有数据修改语句都必须符合在select_ statement中设置的条件。ENCRYPTION:加密视图。SCHEMABINDING:将视图绑定到基础表的架构。VIEW_METADATA:指定为引用视图的查询请求浏览模式的元数据时,SQL Server 实例将向 DB-Library、ODBC 和 OL

16、E DB API 返回有关视图的元数据信息,而不返回基表的元数据信息。2.3 简单用法例一、创建一个视图,用于查看产品、类别和供应商,其代码如下:-创建视图CREATE VIEW view_例一 AS SELECT 产品.产品ID,产品.产品名称,类别.类别名称,供应商.公司名称 FROM 产品 JOIN 类别 ON 产品.类别ID = 类别.类别ID JOIN 供应商 ON 产品.供应商ID = 供应商.供应商IDGO四、SQL SERVER 2000与SQL Server 2008在代码上的一个区别 2000的别名与字段名分开,中间用一个AS,而2008的格式为:别名 AS 字段名五、 一

17、个复杂的视图举例(摘自某应用系统,以下代码为一个视图):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_nameFROM y_z_b, bing_liWHERE y_z_b.daima = bing_li.daima AND y_z_b.zy_bz = 1 AND y_z_b.yz_jj = 1

18、AND y_z_b.feiyong_lb = 0 AND y_z_b.yplb = 1 AND bing_li.fylb = 1UNION ALLSELECT 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_nameFROM y_z_b, bing_liWHERE y_z_b.daima = bing_li.

19、daima AND y_z_b.zy_bz = 1 AND y_z_b.yz_jj = 1 AND y_z_b.feiyong_lb = 0 AND yplb = 2 AND bing_li.fylb = 1UNION ALLSELECT 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_nameFROM y_z

20、_b, bing_liWHERE y_z_b.daima = bing_li.daima AND y_z_b.zy_bz = 1 AND y_z_b.yz_jj = 1 AND y_z_b.feiyong_lb = 0 AND yplb = 3 AND bing_li.fylb = 1UNION ALLSELECT 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_

21、z_b.bq, y_z_b.ch, y_z_b.ys_nameFROM y_z_b, bing_liWHERE y_z_b.daima = bing_li.daima AND y_z_b.zy_bz = 1 AND y_z_b.yz_jj = 1 AND y_z_b.feiyong_lb = 1 AND yplb = 4 AND bing_li.fylb = 1UNION ALLSELECT 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

22、_b.hz_sl, y_z_b.dj, y_z_b.hz_je, 冷暖, y_z_b.bq, y_z_b.ch, y_z_b.ys_nameFROM y_z_b, bing_liWHERE y_z_b.daima = bing_li.daima AND y_z_b.zy_bz = 1 AND y_z_b.yz_jj = 1 AND y_z_b.feiyong_lb = 1 AND yplb = 5 AND bing_li.fylb = 1UNION ALLSELECT bing_li.hos_id + y_z_b.daima, y_z_b.history_date, y_z_b.yphzl,

23、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_nameFROM y_z_b, bing_liWHERE y_z_b.daima = bing_li.daima AND y_z_b.zy_bz = 1 AND y_z_b.yz_jj = 1 AND y_z_b.feiyong_lb = 1 AND yplb = 6 AND bing_li.fylb = 1UNION ALLSELECT bing_li.hos_id + y_z_b.d

24、aima, 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_nameFROM y_z_b, bing_liWHERE y_z_b.daima = bing_li.daima AND y_z_b.zy_bz = 1 AND y_z_b.yz_jj = 1 AND y_z_b.feiyong_lb = 1 AND yplb = 7 AND bing_li.fylb = 1U

25、NION ALLSELECT 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_nameFROM y_z_b, bing_liWHERE y_z_b.daima = bing_li.daima AND y_z_b.zy_bz = 1 AND y_z_b.yz_jj = 1 AND y_z_b.feiyong_lb

26、 = 1 AND yplb = 8 AND bing_li.fylb = 1UNION ALLSELECT 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_nameFROM y_z_b, bing_liWHERE y_z_b.daima = bing_li.daima AND y_z_b.zy_bz = 1 A

27、ND y_z_b.yz_jj = 1 AND y_z_b.feiyong_lb = 1 AND yplb = 9 AND bing_li.fylb = 1UNION ALLSELECT 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_nameFROM y_z_b, bing_liWHERE y_z_b.daim

28、a = bing_li.daima AND y_z_b.zy_bz = 1 AND y_z_b.yz_jj = 1 AND y_z_b.feiyong_lb = 1 AND yplb = 10 AND bing_li.fylb = 1UNION ALLSELECT 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

29、_nameFROM y_z_b, bing_liWHERE y_z_b.daima = bing_li.daima AND y_z_b.zy_bz = 1 AND y_z_b.yz_jj = 1 AND y_z_b.feiyong_lb = 1 AND yplb = 11 AND bing_li.fylb = 1UNION ALLSELECT 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_nameFROM y_z_b, bing_liWHERE y_z_b.daima = bing_li.daima AND y_z_b.zy_bz = 1 A

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

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