Chinaunix首页 | 论坛 | 博客
  • 博客访问: 95919
  • 博文数量: 39
  • 博客积分: 2510
  • 博客等级: 少校
  • 技术积分: 405
  • 用 户 组: 普通用户
  • 注册时间: 2008-09-25 09:25
文章分类

全部博文(39)

文章存档

2011年(1)

2010年(5)

2009年(4)

2008年(29)

我的朋友
最近访客

分类:

2008-10-01 06:11:45

前言
 
    本人有幸参加了公司SLBPS的上线与维护工作,回想近半年来的上线与维护工作,其中有很多感慨,最大的感慨就是累~~所谓少壮不努力,老大做IT,各种滋味,不可与人道也。
    slbps作为全国范围发布的大型分布式系统,是公司在实施数据集中与开发中心一个战略性的部署之一。作为维护人员,不仅需要数据公司产品与业务,也需熟悉相关技术实现细节:数据库,中间件,广域多域,软件工程,小型机,unix系统,运营管理等等,每一个开一个专题都是令人望而生畏的大题目。在网络上也看了不少相关专题的文字,想借用我这个平台,对本身的知识来一次彻底的剖析
 
    slbps客户端:VB
         中间件:Tuxedo
         数据库:informix
         服务器:hp_unix
        
                       专题一 基于索引的SQL优化问题(参考) 
转贴:参考 << 基于索引的SQL优化问题 >>

   客服业务受到SQL语句的影响非常大,在上规模的应用场景下,往往因为一个小的SQL语句不够优化,导致数据库性能急剧下降,小型机idle所剩无几,应用服务器断连、超时,严重影响业务的正常运行。因此,低效的sql是我们维护人员所深恶痛绝的。数据库的优化方法有很多种,在应用层来说,主要是基于索引的优化。

    我们领导说的最多一句话:这帮丫的,写的啥sql,都不走索引。或者是:这丫的,这张表居然没有建索引...囧rz..事实上,给表建立必要的索引是最为考一个数据管理员功底的技术活之一,因为,难点是如何判断这些索引对数据库的性能有没有帮助。具体到方法上,必须对应用程序中所有的sql语句非常熟悉,从中统计出对性能有影响的sql,分析,归纳出作为where条件子句的字段与其组合方式,这个可以判断哪一个字段应该建索引;其次,必须数据应用程序,以此了解哪些表是频繁操作的表,哪些表经常与其它表连接,哪些表数据量比较大,大表中数据分布情况如何等,常用的规则:

    1、表的主键、外键必须有索引;

    2、数据量超过300的表应该有索引;

    3、经常与其他表进行连接的表,在连接字段上应该建立索引;

    4、经常出现在Where子句中的字段,特别是大表的字段,应该建立索引;

    5、索引应该建在选择性高的字段上;

   6、索引应该建在小字段上,对于大的文本字段甚至超长字段,不要建索引;

   7、复合索引的建立需要进行仔细分析;尽量考虑用单字段索引代替:

        A、正确选择复合索引中的主列字段,一般是选择性较好的字段;

     B、复合索引的几个字段是否经常同时以AND方式出现在Where子句中?单字段查询是否极少甚至没有?如果是,则可以建立复合索引;否则考虑单字段索引;

        C、如果复合索引中包含的字段经常单独出现在Where子句中,则分解为多个单字段索引;

        D、如果复合索引所包含的字段超过3个,那么仔细考虑其必要性,考虑减少复合的字段;

       E、如果既有单字段索引,又有这几个字段上的复合索引,一般可以删除复合索引;

   8、频繁进行数据操作的表,不要建立太多的索引;

  9、删除无用的索引,避免对执行计划造成负面影响;

   以上是一些普遍的建立索引时的判断依据。一言以蔽之,索引的建立必须慎重,对每个索引的必要性都应该经过仔细分析,要有建立的依据。因为太多的索引与不充分、不正确的索引对性能都毫无益处:在表上建立的每个索引都会增加存储开销,索引对于插入、删除、更新操作也会增加处理上的开销。 另外,过多的复合索引,在有单字段索引的情况下,一般都是没有存在价值的;相反,还会降低数据增加删除时的性能,特别是对频繁更新的表来说,负面影响更大。

   以下我会逐步加入工作中的常见sql的优化处理。(转帖的文字是基于oracle的 我在informix下面做相关论证,会考虑不同数据库产品对sql优化做的不同处理)
阅读(1070) | 评论(0) | 转发(0) |
0

上一篇:开博感言

下一篇:转帖 2003 批量增加用户

给主人留下些什么吧!~~