原文:
避免对索引列进行计算
操作系统:Windows 2007
数据库版本:SQL SERVER 2005
发表日期:2014-11-07 16:56:01
今天同事让我看一条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时,不到万不得已,不要对索引列进行计算。

