SQL Server索引管理六大铁律
索引管理六大铁律(上)
索引是以表列为基础的数据库对象。索引中保存着表中排序的索引列,并且纪录了索引列在数据库表中的物理存储位置,实现了表中数据的逻辑排序。通过索引,可以加快数据的查询速度和减少系统的响应时间;可以使表和表之间的连接速度加快。
但是,不是在任何时候使用索引都能够达到这种效果。若在不恰当的场合下,使用索引反而会事与愿违。所以,在SQL Server数据库中使用索引的话,还是需要遵守一定的规则。笔者觉得,主要是需要遵守六大铁律。
铁律一:天下没有免费的午餐,使用索引是需要付出代价的。
索引的优点有目共睹,但是,却很少有人关心过采用索引所需要付出的成本。若数据库管理员能够对索引所需要付出的代价有一个充分的认识,也就不会那么随意到处建立索引了。
仔细数数,其实建立索引的代价还是蛮大的。如创建索引和维护索引都需要花费时间与精力。特别是在数据库设计的时候,数据库管理员为表中的哪些字段需要建立索引,要调研、要协调。如当建有索引的表中的纪录又增加、删除、修改操作时,数据库要对索引进行重新调整。虽然这个工作数据库自动会完成,但是,需要消耗服务器的资源。当表中的数据越多,这个消耗的资源也就越多。如索引是数据库中实际存在的对象,所以,每个索引都会占用一定的物理空间。若索引多了,不但会占用大量的物理空间,而且,也会影响到整个数据库的运行性能。
可见,数据库管理员若要采用索引来提高系统的性能,自身仍然需要付出不少的代价。数据库管理员现在要考虑的就是如何在这两个之间取得一个均衡。或者说,找到一个回报与投入的临界点。
铁律二:对于查询中很少涉及的列或者重复值比较多的列,不要建立索引。
在查询的时候,如果我们不按某个字段去查询,则在这个字段上建立索引也是浪费。如现在有一张员工信息表,我们可能按员工编号、员工姓名、或者出身地去查询员工信息。但是,我们往往不会按照身份证号码去查询。虽然这个身份证号码是唯一的。此时,即使在这个字段上建立索引,也不能够提高查询的速度。相反,增加了系统维护时间和占用了系统空间。这简直就是搬起石头砸自己的脚呀。
另外,如上面的员工信息表,有些字段重复值比较多。如性别字段主要就是“男”、“女”;职位字段中也是有限的几个内容。此时,在这些字段上添加索引也不会显著的增加查询速度,减少用户响应时间。相反,因为需要占用空间,反而会降低数据库的整体性能。
数据库索引管理中的第二条铁律就是,对于查询中很少涉及的列或者重复值比较多的列,不要建立索引。
铁律三:对于按范围查询的列,最好建立索引。
在信息化管理系统中,很多时候需要按范围来查询某些交易记录。如在erp系统中,经常需要查询当月的销售订单与销售出货情况,这就需要按日期范围来查询交易记录。如有时候发现库存不对时,也需要某段时期的库存进出情况,如5月1日到12月3日的库存交易情况等等。此时,也是根据日期来进行查询。
对于这些需要在指定范围内快速或者频繁查询的数据列,需要为其建立索引。因为索引已经排序,其保存的时候指定的范围是连续的,查询可以利用索引的排序,加快查询时间,减少用户等待时间。
不过,若虽然可能需要按范围来进行查询,但是,若这个范围查询条件利用的不多的情况下,最好不好采用索引。如在员工信息表中,可能需要查询2008年3月份以前入职的员工明细,要为他们增加福利。但是,由于表中记录不多,而且,也很少进行类似的查询。若维这个字段建立索引,虽然无伤大雅,但是很明显,索引所获得的收益要低于其成本支出。对数据库管理员来说,是得不偿失的。
再者,若采用范围查询的话,最好能利用TOP关键字来限制一次查询的结果。如第一次按顺序只显示前面的500条记录等等。把TOP关键字跟范围一起使用,可以大大的提高查询的效率。
- 1文档安全加密系统的技术研究和实现方式
- 2确保Windows操作系统稳定的六个秘笈
- 3全球救市计划可能推动高性能计算发展
- 4为什么SaaS可以令IT技能无关紧要
- 5如何高效管理企业的基础应用服务?
- 6“安全第一” 企业如何利用EFS加密数据
- 7IDC:全球经济危机给云计算带来曙光
- 8利用数据重复删除技术实现更优存储
- 9安全管理日志 寻找云计算的一线希望
- 10Gartner:数据中心的操作急需现代化
- 112010年数据中心自动化市场将达150亿美元
- 12CIO不得不面对的数据中心四大变革
- 13采取7项措施来建设更绿色数据中心
- 14中小企业应如何着手服务器虚拟化部署
- 15分析:虚拟化技术给企业应用带来的优势
- 16超量的存储采购将影响未来的存储预算
- 17计世独家:10大IT节电误区 勿入电力危机
- 18主流灾难备份与恢复技术分析
- 19带头执行,关于组织的OA使用来说必定事半功倍
- 20云计算背后:缺乏标准 风险谁来承担
- 21企业机密数据防护由安全管理员控制入手
- 22IT管理者应该如何应对虚拟风险的出现
- 23比尔·盖茨:云存储会比云计算更流行
- 24不要让云计算成为皇帝的新衣
- 25调查:虚拟化技术在向中型企业渗透
- 26注意提防统一通信带来的安全威胁
- 27安全思考:谁在“借用”您的网络?
- 28CTO解读企业数据安全管理与防护
- 29如何削减虚拟化策略的存储需求
- 30IT安全能够免疫经济衰退吗?