当前位置:  数据库>sqlserver

优化 SQL Server 索引的小技巧

    来源: 互联网  发布时间:2014-10-08

    本文导语:  在本文中,我将说明如何用SQL Server的工具来优化数据库索引的使用,本文还涉及到有关索引的一般性知识。      关于索引的常识      影响到数据库性能的最大因素就是索引。由于该问题的复杂性,我只可能简单的...

在本文中,我将说明如何用SQL Server的工具来优化数据库索引的使用,本文还涉及到有关索引的一般性知识。
  
  关于索引的常识
  
  影响到数据库性能的最大因素就是索引。由于该问题的复杂性,我只可能简单的谈谈这个问题,不过关于这方面的问题,目前有好几本不错的书籍可供你参阅。我在这里只讨论两种SQL Server索引,即clustered索引和nonclustered索引。当考察建立什么类型的索引时,你应当考虑数据类型和保存这些数据的column。同样,你也必须考虑数据库可能用到的查询类型以及使用的最为频繁的查询类型。
  
  索引的类型

  如果column保存了高度相关的数据,并且常常被顺序访问时,最好使用clustered索引,这是因为如果使用clustered索引,SQL Server会在物理上按升序(默认)或者降序重排数据列,这样就可以迅速的找到被查询的数据。同样,在搜寻控制在一定范围内的情况下,对这些column也最好使用clustered索引。这是因为由于物理上重排数据,每个表格上只有一个clustered索引。
  
  与上面情况相反,如果columns包含的数据相关性较差,你可以使用nonculstered索引。你可以在一个表格中使用高达249个nonclustered索引——尽管我想象不出实际应用场合会用的上这么多索引。
  
  当表格使用主关键字(primary keys),默认情况下SQL Server会自动对包含该关键字的column(s)建立一个独有的cluster索引。很显然,对这些column(s)建立独有索引意味着主关键字的唯一性。当建立外关键字(foreign key)关系时,如果你打算频繁使用它,那么在外关键字cloumn上建立nonclustered索引不失为一个好的方法。如果表格有clustered索引,那么它用一个链表来维护数据页之间的关系。相反,如果表格没有clustered索引,SQL Server将在一个堆栈中保存数据页。
  
  数据页

  当索引建立起来的时候,SQLServer就建立数据页(datapage),数据页是用以加速搜索的指针。当索引建立起来的时候,其对应的填充因子也即被设置。设置填充因子的目的是为了指示该索引中数据页的百分比。随着时间的推移,数据库的更新会消耗掉已有的空闲空间,这就会导致页被拆分。页拆分的后果是降低了索引的性能,因而使用该索引的查询会导致数据存储的支离破碎。当建立一个索引时,该索引的填充因子即被设置好了,因此填充因子不能动态维护。
  
  为了更新数据页中的填充因子,我们可以停止旧有索引并重建索引,并重新设置填充因子(注意:这将影响到当前数据库的运行,在重要场合请谨慎使用)。DBCC INDEXDEFRAG和DBCC DBREINDEX是清除clustered和nonculstered索引碎片的两个命令。INDEXDEFRAG是一种在线操作(也就是说,它不会阻塞其它表格动作,如查询),而DBREINDEX则在物理上重建索引。在绝大多数情况下,重建索引可以更好的消除碎片,但是这个优点是以阻塞当前发生在该索引所在表格上其它动作为代价换取来得。当出现较大的碎片索引时,INDEXDEFRAG会花上一段比较长的时间,这是因为该命令的运行是基于小的交互块(transactional block)。
  
  填充因子

  当你执行上述措施中的任何一个,数据库引擎可以更有效的返回编入索引的数据。关于填充因子(fillfactor)话题已经超出了本文的范畴,不过我还是提醒你需要注意那些打算使用填充因子建立索引的表格。
  
  在执行查询时,SQL Server动态选择使用哪个索引。为此,SQL Server根据每个索引上分布在该关键字上的统计量来决定使用哪个索引。值得注意的是,经过日常的数据库活动(如插入、删除和更新表格),SQL Server用到的这些统计量可能已经“过期”了,需要更新。你可以通过执行DBCC SHOWCONTIG来查看统计量的状态。当你认为统计量已经“过期”时,你可以执行该表格的UPDATE STATISTICS命令,这样SQL Server就刷新了关于该索引的信息了。
  
  建立数据库维护计划

  SQL Server提供了一种简化并自动维护数据库的工具。这个称之为数据库维护计划向导(Database Maintenance Plan Wizard ,DMPW)的工具也包括了对索引的优化。如果你运行这个向导,你会看到关于数据库中关于索引的统计量,这些统计量作为日志工作并定时更新,这样就减轻了手工重建索引所带来的工作量。如果你不想自动定期刷新索引统计量,你还可以在DMPW中选择重新组织数据和数据页,这将停止旧有索引并按特定的填充因子重建索引。

    
 
 

您可能感兴趣的文章:

  • mysql优化之路----hash索引优化
  • MySQL查询优化之索引的应用详解
  • MySQL 联合索引与Where子句的优化 提高数据库运行效率
  • SQL优化基础 使用索引(一个小例子)
  • MySQL 通过索引优化含ORDER BY的语句
  • MySQL Order By索引优化方法
  • SqlServer 索引自动优化工具
  • Sql Server 索引使用情况及优化的相关Sql语句分享
  • Mysql limit 优化,百万至千万级快速分页 复合索引的引用并应用于轻量级框架
  • Sql Server 查询性能优化之走出索引的误区分析
  • MySQL索引背后的之使用策略及优化(高性能索引策略)
  • MySQL 索引分析和优化
  • Oracle CBO优化模式中的5种索引访问方法浅析
  • Mysql大表查询优化技巧总结及案例分析
  • ORACLE SQL-UPDATE、DELETE、INSERT优化和使用技巧分享
  • 总结MySQL建表、查询优化的一些实用小技巧
  • SQL Server 服务器优化技巧浅谈
  • 解析Android开发优化之:从代码角度进行优化的技巧
  • PHP小技巧之JS和CSS优化工具Minify的使用方法
  • MySQL性能优化的一些技巧帮助你的数据库
  • 解析MySQL数据库性能优化的六大技巧
  • sql优化技巧大全 sql优化注意事项
  • MySQL数据库十大优化技巧
  • css代码优化的12个技巧
  • 揭秘SQL优化技巧 改善数据库性能
  • 101个MySQL优化技巧和提示
  • SQL优化技巧指南
  • Python 代码性能优化技巧分享
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 网站解决和优化Server is too busy的一些方法
  • SQL Server数据库的高性能优化经验总结
  • SQL SERVER的优化建议与方法
  • SQL SERVER 的SQL语句优化方式小结
  • 人工智能自动sql优化工具--SQLTuning for SQL Server
  • 优化SQL Server的内存占用之执行缓存
  • SQL Server游标的使用/关闭/释放/优化小结
  • SQL Server 数据库优化
  • SQL Server中的SQL语句优化与效率问题
  • SQL SERVER性能优化综述(很好的总结,不要错过哦)第1/3页
  • SQL Server优化50法汇总
  • Sql Server查询性能优化之不可小觑的书签查找介绍
  • MSSQL Server 查询优化方法 整理
  • sql语句优化之SQL Server(详细整理)
  • tcmalloc内存泄露优化c++开源库下载,安装及使用介绍
  • GCC的O1、O2、O3选项究竟优化了什么?
  • Windows优化大师最新版 V7.99 Build 12.604发布
  • 解析Android开发优化之:对界面UI的优化详解(三)
  • MySQL优化分析器 mysqloa
  • JPEG 图像优化工具 jpegoptim
  • 图片优化工具 ImageOptim
  • 一个编译优化问题
  • gcc 优化
  • 急,来者有分,怎样对程序中的SQL语句进行优化
  • SPICE 电路优化 ASCO
  • IIS 优化扩展 IISpeed
  • 流量优化的网络驱动程序 cFosSpeed
  • CSS优化工具 CSSTidy
  • 搜索引擎优化工具 Seo Panel
  • gcc编联优化问题?
  • 【请教】只提供几个文件下载的apache如何优化?


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3