有些朋友看到这个标题可能会有疑问,难道在视图中使用*符号还有何要注意的地方吗?对于这个问题,我们先不必回答,先看一下例子吧。
我这里,使用的数据库是SQL Server 2000自带的Northwind,这样方便大家自己私下里测试。首先,创建两个视图,视图的脚本如下:
–视图 VCustomersA create view vCustomersA as select CustomerID ,CompanyName,ContactName,ContactTitle, Address,City,Region,PostalCode,Country,Phone,Fax from dbo.Customers go –视图 vCustomersB create view vCustomersB as select * from vCustomersA go |
然后,使用这两个视图查询客户ID为ALFKI的资料,查询语句如下:
select * from vCustomersA where CustomerID = ‘ALFKI’
select * from vCustomersB where CustomerID = ‘ALFKI’
查询的结果如下:
一切正常,这个时候,需求发生了变化,我们需要改动vCustomersA,改动后的脚本如下:(为了说明问题,我们只是把CompanyName和ContactName互换一下位置)
–改动后的视图vCustomersA alter view vCustomersA as select CustomerID ,ContactName,CompanyName,ContactTitle, Address,City,Region,PostalCode,Country,Phone,Fax from dbo.Customers go |
这个时候,当我们再次使用视图vCustomersB查询客户ID为ALFKI的资料的时候,错误已经悄然来临,你注意到了吗?让我们来看一下这两个视图的查询结果吧,查询语句如下:
select * from vCustomersA where CustomerID = ‘ALFKI’
select * from vCustomersB where CustomerID = ‘ALFKI’
查询的结果发生变化。你注意到数据的异常了吗?使用视图vCustomersB查询的结果出现了错误,CompanyName显示的资料是:Maria Anders,而在视图vCustomersA查询的结果中CompanyName是:Alfreds Futterkiste。我们仅仅是在vCustomersA中互换了两个字段的位置,再次使用vCustomersB查询数据却发生了数据错位的现象,这是什么原因导致的呢?
带着这个问题,让我们去了解一下,何谓视图?在SQL Server2000的帮助文档中是这样描述视图的,定义如下:“视图是一个虚拟表,其内容由查询定义,同真实的表一样,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。行和列数据来自由定义视图的查询所引用的表,并且在引用视图时动态生成。”通过这个定义我们可以看出,视图是一个虚拟的表,它仅仅包括视图的定义脚本,查询的内容则是动态的生成。当我们创建了一个视图以后,视图的脚本会保存到当前数据库的系统表syscomments里,我们可以通过系统提供的存储过程:sp_helptext查询得到视图的定义脚本。从定义上看,好像并不能得到我们想要的答案,那么我们就先不管Sql Server 2000是如何实现视图的,我们先来解决一下当前的问题(我上面提到的)。可能有些朋友已经知道了解决问题的办法了,那就是把vCustomersB的定义脚本重新执行一下(其实只需要把create换成alter执行一下就可以),脚本如下:
–重新执行一下vCustomersB的定义脚本
alter view vCustomersB as select * from vCustomersA go |
我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。
我原创,你原创,我们的内容世界才会更加精彩!
【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】
微信公众号
TechTarget
官方微博
TechTarget中国
相关推荐
-
分析SQL Server级联删除的实现
SQL Server 2000与Oracle 8i相比,SQL Server级联删除有太多的限制,本文就为您介绍SQLServer级联删除的实现方法,供您参考。
-
从SQL Server中的数据更新到Oracle表中
我有两个客户端服务程序。一个用的是Oracle7数据库,而另一个用的是SQL Server 2000。现在我想把SQL Server 2000中的某些表数据更新到Oracle数据库表中……
-
SQL Server索引设计和调优技巧大全
本技术专题主要围绕sql server设计这个话题展开,侧重介绍了sql server集簇索引的设计、如何创建sql server索引、如何优化索引、索引的能与不能、处理sql server 2000索引碎片技巧以及维护sql server索引以实现查询优化等等。
-
处理SQL Server 2000索引碎片技巧(三)
如何处理SQL Server 2000索引碎片?本文介绍了处理SQL Server 2000索引碎片技巧中的三大技巧:确定碎裂的索引、重建碎裂的索引以及配置数据库……