物化视图SQLServer数据库
小职 2018-07-02 来源 : 阅读 1418 评论 0

摘要:本文主要向大家介绍了物化视图SQLServer数据库,通过具体的内容向大家展示,希望能对大家学习SQLServer数据库有所帮助。

本文主要向大家介绍了物化视图SQLServer数据库,通过具体的内容向大家展示,希望能对大家学习SQLServer数据库有所帮助。

物化视图,所谓视图实际上是不存储物理信息的(同表相区别,表存储实际的数据和表的索引信息等。),视图仅仅存储  一个select语句而已。而物化视图就要视图也存储实际的数据,这种实际数据,就是索引。oracle   8imssqlserver2000中引入的。比如oracle的函数索引和sqlserver2000的索引视图都是物化视图。原因是这种视图能够显著提高性能,举个例子   
  一个表:

  create  table  mytable   (id   int   not   null,name   varchar(20)   not   null)   
  create   index   idx_mytable   on   mytable.name   
  当我们查询的时候,

  select   *   from   mytable   where   name   like   'j%',

  优化器能够使用索引来提高性能,然而我们遇到这种情况就不能使用索引了,如:   
  select   *   from   mytable   where   name   like   '%bing%'   
  或者   
  select   *   from   mytable   where   substring(name,1,5)='jiang'   
  这样的情况不能使用索引   
  但引入物化视图就不同了   
  create   view   myview(vid,vname)   as   select   id,substring(name,1,5)   from   myview.   
  然后再vname上建立索引即可显著提高查询性能。   
  oracle的函数索引亦是如此。   
  create   index   idx_mytable   on   mytable(upper(name))   
  --   
  就是这样的  

1.6.2   物化视图

SQL Server 2005增强了索引化视图,也叫做物化视图。现在你可以使用一个能索引化的视图扩展集合了。在SQL Server中还有一些可以被索引化的视图类型,如使用下列选项的视图:

外部连接(Outer Joins)。
级联集合(Scalar Aggregates)。
ROLLUP和CUBE。

当数据库管理员或者开发者在视图上创建索引时,这个视图就被物化(执行)了,并且结果集被永久地保存在唯一聚簇索引(Clustered Index)中,保存方式与一个有聚簇索引的表的保存方式相同。可以在第一级唯一聚簇索引创建之后添加非聚簇的第二级索引。

索引视图有以下两个优点。

减除了为引用视图的查询动态建立结果集的管理开销。
优化人员可以在查询中使用视图索引,而不需要在FROM子句中直接指定视图。
引用索引化视图中的相关列的现有查询可以受益于提高了的在索引化视图中获取数据的效率,而且不需要重新编写代码。

本文由职坐标整理并发布,了解更多内容,请关注职坐标SQL Server数据库频道!


本文由 @小职 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程