国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > 綜合 > 正文

避免對索引列進行計算

2024-07-21 02:48:39
字體:
來源:轉載
供稿:網友
避免對索引列進行計算

操作系統:Windows 2007

數據庫版本:SQL SERVER 2005

  今天同事讓我看一條SQL,說是在前臺查詢很快,但是把SQL取出來,在數據庫中執行的時候,跑10分鐘都不出結果。

看了一下SQL,最后定位到一個視圖中的一個子查詢上面。該子查詢的SQL文本如下:

SELECT  acinv_07.id_item ,        SUM(acinv_07.dec_endqty) dec_endqtyFROM    acinv_07WHERE   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時,不到萬不得已,不要對索引列進行計算。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 沛县| 广汉市| 新民市| 南川市| 邮箱| 龙江县| 叙永县| 界首市| 定远县| 徐汇区| 磐石市| 兴安县| 涿鹿县| 南康市| 靖边县| 应用必备| 克什克腾旗| 临江市| 纳雍县| 周至县| 巴塘县| 古蔺县| 修水县| 调兵山市| 石首市| 合肥市| 临海市| 镇安县| 延安市| 灵璧县| 田东县| 朝阳市| 六枝特区| 科技| 昭觉县| 襄垣县| 莲花县| 漳平市| 惠安县| 大连市| 合川市|