首页 > 代码库 > 避免对索引列进行计算
避免对索引列进行计算
操作系统: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_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时,不到万不得已,不要对索引列进行计算。
避免对索引列进行计算
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。