浅谈SQL Server中统计对于查询的影响分析(2)

来源:asp之家 时间:2012-06-06 20:08:23 

统计信息的更新

由上面的例子可以看到,查询分析器由于依赖于统计信息进行查询,那么过时的统计信息则可能导致低效率的查询。统计信息既可以由SQL Server来进行管理,也可以手动进行更新,也可以由SQL Server管理更新时手动更新。

当开启了自动更新后,SQL Server监控表中的数据更改,当达到临界值时则会自动更新数据。这个标准是:

向空表插入数据时 少于500行的表增加500行或者更多 当表中行多于500行时,数据的变化量大于20%时

上述条件的满足均会导致统计被更新。

当然,我们也可以使用如下语句手动更新统计信息。


UPDATE STATISTICS 表名[索引名]

列级统计信息

SQL Server还可以针对不属于任何索引的列创建统计信息来帮助查询分析器获取”估计的行数“.当我们开启数据库级别的选项“自动创建统计信息”如图6所示。

图6.自动创建统计信息

当这个选项设置为True时,当我们where谓词指定了不在任何索引上的列时,列的统计信息会被创建,但是会有以下两种情况例外:

创建统计信息的成本超过生成查询计划的成本 当SQL Server忙时不会自动生成统计信息

我们可以通过系统视图sys.stats来查看这些统计信息,如图7所示。

图7.通过系统视图查看统计信息

当然,也可以通过如下语句手动创建统计信息:

CREATE STATISTICS 统计名称 ON 表名 (列名 [,...n])

总结

本文简单谈了统计信息对于查询路径选择的影响。过时的统计信息很容易造成查询性能的降低。因此,定期更新统计信息是DBA重要的工作之一。

标签:统计,查询
0
投稿

猜你喜欢

  • CSS Frameworks的概念

    2008-01-23 18:41:00
  • Oracle字符集修改查看方法

    2009-11-05 21:45:00
  • 用户体验的另一种认识

    2007-10-25 12:36:00
  • FCKeditor编辑器实战技巧

    2007-10-08 21:13:00
  • 在sql中返回插入的记录的id

    2008-12-21 15:54:00
  • ASP同一站点不同编码程序出现乱码解决办法

    2008-11-10 12:08:00
  • position、z-index、top、right、bottom和left属性

    2009-10-04 20:33:00
  • XML轻松学习手册(3)XML的术语

    2008-09-05 17:17:00
  • 关于 MediaPlayer 播放器参数详解

    2008-08-10 18:33:00
  • 利用SQLyogEnt对Mysql数据库进行转移

    2012-02-25 20:17:30
  • jQuery 横向滚动图片

    2009-03-11 13:09:00
  • ASP下标越界错误的解决方法

    2008-10-19 17:39:00
  • 丰富段落里的标签

    2008-03-16 14:11:00
  • [翻译]标记语言和样式手册 Chapter 2 标题

    2008-01-16 11:56:00
  • 隐蔽的ASP后门 大家可以查看下

    2010-08-05 21:26:00
  • Http头 Range、Content-Range

    2010-06-25 19:19:00
  • eWebEditor不支持IE,IE8,IE7,火狐,遨游的解决方法

    2011-06-06 07:57:00
  • 解读iPhone平台的一些优秀设计思路

    2010-06-24 21:53:00
  • 用于打印的页面设计

    2009-07-06 12:47:00
  • 浏览器右下角弹出提示窗口

    2008-10-30 12:37:00
  • asp之家 网络编程 m.aspxhome.com