SQL Server索引管理之六大铁律

来源:asp之家 时间:2009-11-26 14:55:00 

索引是以表列为基础的数据库对象。索引中保存着表中排序的索引列,并且纪录了索引列在数据库表中的物理存储位置,实现了表中数据的逻辑排序。通过索引,可以加快数据的查询速度和减少系统的响应时间;可以使表和表之间的连接速度加快。 但是,不是在任何时候使用索引都能够达到这种效果。若在不恰当的场合下,使用索引反而会事与愿违。所以,在SQL Server数据库中使用索引的话,还是需要遵守一定的规则。

铁律一:天下没有免费的午餐,使用索引是需要付出代价的

索引的优点有目共睹,但是,却很少有人关心过采用索引所需要付出的成本。若数据库管理员能够对索引所需要付出的代价有一个充分的认识,也就不会那么随意到处建立索引了。

仔细数数,其实建立索引的代价还是蛮大的。如创建索引和维护索引都需要花费时间与精力。特别是在数据库设计的时候,数据库管理员为表中的哪些字段需要建立索引,要调研、要协调。如当建有索引的表中的纪录又增加、删除、修改操作时,数据库要对索引进行重新调整。虽然这个工作数据库自动会完成,但是,需要消耗服务器的资源。当表中的数据越多,这个消耗的资源也就越多。如索引是数据库中实际存在的对象,所以,每个索引都会占用一定的物理空间。若索引多了,不但会占用大量的物理空间,而且,也会影响到整个数据库的运行性能。

可见,数据库管理员若要采用索引来提高系统的性能,自身仍然需要付出不少的代价。数据库管理员现在要考虑的就是如何在这两个之间取得一个均衡。或者说,找到一个回报与投入的临界点。

铁律二:对于查询中很少涉及的列或者重复值比较多的列,不要建立索引

在查询的时候,如果我们不按某个字段去查询,则在这个字段上建立索引也是浪费。如现在有一张员工信息表,我们可能按员工编号、员工姓名、或者出身地去查询员工信息。但是,我们往往不会按照身份证号码去查询。虽然这个身份证号码是唯一的。此时,即使在这个字段上建立索引,也不能够提高查询的速度。相反,增加了系统维护时间和占用了系统空间。这简直就是搬起石头砸自己的脚呀。

另外,如上面的员工信息表,有些字段重复值比较多。如性别字段主要就是“男”、“女”;职位字段中也是有限的几个内容。此时,在这些字段上添加索引也不会显著的增加查询速度,减少用户响应时间。相反,因为需要占用空间,反而会降低数据库的整体性能。

数据库索引管理中的第二条铁律就是,对于查询中很少涉及的列或者重复值比较多的列,不要建立索引。

铁律三:对于按范围查询的列,最好建立索引

在信息化管理系统中,很多时候需要按范围来查询某些交易记录。如在ERP系统中,经常需要查询当月的销售订单与销售出货情况,这就需要按日期范围来查询交易记录。如有时候发现库存不对时,也需要某段时期的库存进出情况,如5月1日到12月3日的库存交易情况等等。此时,也是根据日期来进行查询。

对于这些需要在指定范围内快速或者频繁查询的数据列,需要为其建立索引。因为索引已经排序,其保存的时候指定的范围是连续的,查询可以利用索引的排序,加快查询时间,减少用户等待时间。

不过,若虽然可能需要按范围来进行查询,但是,若这个范围查询条件利用的不多的情况下,最好不好采用索引。如在员工信息表中,可能需要查询2008年3月份以前入职的员工明细,要为他们增加福利。但是,由于表中记录不多,而且,也很少进行类似的查询。若维这个字段建立索引,虽然无伤大雅,但是很明显,索引所获得的收益要低于其成本支出。对数据库管理员来说,是得不偿失的。

再者,若采用范围查询的话,最好能利用TOP关键字来限制一次查询的结果。如第一次按顺序只显示前面的500条记录等等。把TOP关键字跟范围一起使用,可以大大的提高查询的效率。

标签:MySQL,数据库,Mysql数据库,数据库命令
0
投稿

猜你喜欢

  • 在那里修改godaddy的首页默认访问文件?

    2010-04-16 12:56:00
  • 双机热备、集群服务器等必须注意的事项

    2008-08-14 14:53:00
  • linux下AutoFs挂载服务安装教程

    2021-05-07 08:15:42
  • Vmware虚拟机设置固定IP地址的方法( 图文教程)

    2022-09-30 05:15:25
  • 草根站长要成功,应该从思想上突围

    2007-12-03 21:11:00
  • 关于在IIS中使用Gzip页面压缩

    2009-04-30 12:58:00
  • 浅析Apache服务器中SSI和CGI设定方法

    2010-05-08 17:59:00
  • SERV-U 技巧

    2009-11-28 15:28:00
  • 手把手教你使用 virtualBox 让虚拟机连接网络的教程

    2021-01-08 00:43:32
  • 许三多与个人网站扯上的关系

    2007-11-18 14:03:00
  • 微软称绕开Vista从XP升级到Windows 7很危险

    2008-06-09 19:13:00
  • 十分钟快速架设Linux系统下WebMail

    2010-03-12 18:47:00
  • AdSense又一新功能 - 广告查看中心

    2007-12-19 12:49:00
  • 在Windows IIS下配置WordPress MU环境

    2008-05-28 13:56:00
  • 巧妙配置Win2003自带mail服务器

    2008-12-24 14:36:00
  • 教你一招 小流量网站站长照样赚钱

    2009-09-25 09:40:00
  • 教你如何成为网赚高手

    2009-05-24 07:32:00
  • 改进你的WordPress导航菜单-输出标题描述

    2011-12-07 11:00:27
  • 网络安全之小技巧保护(IIS)Web服务器

    2007-03-28 16:44:00
  • 2008年适用 搜索引擎算法200个相关因素

    2008-12-11 10:36:00
  • asp之家 网站运营 m.aspxhome.com