欢迎来到天天文库
浏览记录
ID:33847702
大小:36.50 KB
页数:3页
时间:2019-03-01
《关于sql中view语句的详细讲解》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库。
1、关于SQL中View语句的详细讲解众所周知,View就是命名了的SQL语句,在数据库中以虚表形式存在的对象。为什么说是虚表,因为View中呈现给用户的数据完全是存储在来自于View的底层对象---Table中。View有三种类型:RegularView,UpdateableView以及IndexedView。下面我们就来探讨一下View的共性。创建View的语法为:CreateViewv_Name[With]AsSQLstatement[WithCheckOption]其中View_Attribute包括
2、三种属性:1)Encryption:加密视图定义,一旦视图被加密,任何人都无法看到视图的定义,包括数据库管理员和系统管理员对无法对加密的视图定义进行解密,所以以后不能对加密的视图进行维护,只能drop掉然后重新Create,所以在你决定加密视图定义之前最好有一个该视图定义的备份。2)Schemabinding:架构绑定。如果你所创建的视图附带了这个属性,那么任何在该视图中关联的表、视图都无法被drop掉,除非首先drop掉这个视图。所以一些数据库管理员在创建数据库表的时候,会创建一个和表结构一样的Sche
3、mabinding视图,即使这个视图从来不用,这样做的目的就是防止一些关键性的表被系统管理员不小心drop掉。3)View_Metadata:如果创建视图的时候附带这个属性,TheVIEW_METADATAoptionreturnsmetadataaboutaviewtoclient-sidedataaccesslibraries.另外在创建视图的时候也有如下四条限制:1)不能使用Compute/Computeby/Option语句2)不能使用INTO关键字3)不能引用临时表和表变量4)不能使用order
4、by语句,除非有top关键字存在另外一个对视图对象要关注的就是权限问题,由于视图可能引用很多表,所以对视图有select权限的User,并不一定对视图所引用的基表有Select权限。比如下图:T_Customer---------------------->V_CustomerAddress<--------------------------T_AddressOwnedbyUserAOwnedbyUserBOwnedbyUserC假如UserA把select该视图的权限grant给了UserD,此时,U
5、serD访问V_CustomerAddress是有权限的,但是会得到错误信息:UserD没有selectT_Customer和T_Address的Permission。所以为了保证UserD可以正常访问该视图之前应该做以下事情:1)UserAgrantsUserDSELECTpermissiontoviewv_CustomerAddress.2)UserBgrantsUserDSELECTpermissiontotablet_Customer.3)UserCgrantsUserDSELECTpermiss
6、iontotablet_Address.另外一个就是视图的SQL替代,比如视图中join视图,则在QE(QueryExecutor)执行之前,QO(QueryOptimizer)会把视图中的引用替换为视图定义的表引用,这个是一些理论性的东西。QO就相当于数据库的军师,会在执行之前找最优的ExecutePlan(执行计划),实际上QO还有很多值得惊讶的功能。以上所探讨的就是View的共性,下面具体研究一下视图中的非常规视图:可更新视图(UpdateableView)和索引视图(IndexedView)1>U
7、pdateableView对于可更新视图,主要是WithCheckOption选项,在SQL2000中,视图只有select功能,但是到了SQL2005中,视图同时具有了select,insert,update和delete的功能,假如我们创建一个视图如下(没有withcheckoption选项):CreateviewScoreViewwithschemabinding--Mainlyusedforsecurityissue.asselectName,Subject,Resultfromdbo.score
8、whereResult>80这个时候如果我们执行insertintoScoreViewvalues('Bosco','English',71)操作,返回1rowaffected,表明插入成功,但是我们再执行select*fromScoreView的时候确看不到刚才添加的记录,因为71<80,这个时候用户会误认为数据丢失了,或者没有添加成功,为了使用户不迷惑,我们可以把刚才的的视图定义修改为:alterviewScoreView
此文档下载收益归作者所有