• 避免对索引列进行计算


    操作系统:Windows 2007

    数据库版本:SQL SERVER 2005

      今天同事让我看一条SQL,说是在前台查询很快,但是把SQL取出来,在数据库中执行的时候,跑10分钟都不出结果。

    看了一下SQL,最后定位到一个视图中的一个子查询上面。该子查询的SQL文本如下:

    SELECT  acinv_07.id_item ,
            SUM(acinv_07.dec_endqty) dec_endqty
    FROM    acinv_07
    WHERE   acinv_07.fiscal_year * 100 + acinv_07.fiscal_period 
            = ( SELECT DISTINCT
                       ctlm1101.fiscal_year * 100 + ctlm1101.fiscal_period
                       FROM ctlm1101 WHERE flag_curr = 'Y'
                       AND id_oprcode = 'acinv'
                       AND acinv_07.id_wh = ctlm1101.id_table)
    GROUP BY acinv_07.id_item

      在acinv_07表上的列fiscal_year和列fiscal_period是有索引的。但是,如果对索引列进行运算,就会导致原本可以走索引的走不了索引。于是,动手改写成如下SQL:

    SELECT    id_item ,
                        SUM(dec_qty) dec_qty
              FROM      dpurreq_03
              GROUP BY  id_item
            ) a ,
            ( SELECT    a.id_item ,
                        SUM(a.dec_endqty) dec_endqty
              FROM      acinv_07 a ,
                        ( SELECT DISTINCT
                                    ctlm1101.fiscal_year ,
                                    ctlm1101.fiscal_period ,
                                    id_table
                          FROM      ctlm1101
                          WHERE     flag_curr = 'Y'
                                    AND id_oprcode = 'acinv'
                        ) b
              WHERE     a.fiscal_year = b.fiscal_year
                        AND a.fiscal_period = b.fiscal_period
                        AND a.id_wh = b.id_table
              GROUP BY  a.id_item

      再执行,4s钟左右就可以跑出结果了。

      对于开发来说,纯粹是为了实现把结果数据展示出来,而不会过多考虑SQL的性能问题。

      总结

      写SQL时,不到万不得已,不要对索引列进行计算。

  • 相关阅读:
    Lc169_多数元素
    Lc461_汉明距离
    有返回值的多线程
    Lc344_反转字符串
    Lc709_转换成小写字母
    Lc1436_旅行终点站
    Spring 注解回顾
    SpringCloud网关之Zuul
    SpringCloud注册中心之Zookeeper
    SpringCloud服务安全之hystrix
  • 原文地址:https://www.cnblogs.com/boss-he/p/4081731.html
Copyright © 2020-2023  润新知