操作系统:Windows XP

  数据库版本:SQL Server 2005

  今天遇到一个SQL,过滤条件是自动生成的,因此,没法通过调整SQL的谓词达到优化的目的,只能去找SQL中的“大表”。有一个视图返回的结果集比较大,如果能调整的话,也只能调整该视图了。

  看了一下该视图的结构,里面还套用了另一层视图,直接看最里层视图的查询SQL。

SELECT  a.dfeesum_no ,
a.opr_amt - ISNULL(b.dec_pay, 0) - ISNULL(b.dec_corrpay, 0)
- ISNULL(b.dec_deduamt, 0) dec_amt ,
a.dec_camt - ISNULL(b.dec_pay, 0) - a.dec_comprate
* ISNULL(b.dec_deduamt, 0) dec_compamt ,
a.dec_ramt - ISNULL(b.dec_corrpay, 0) - ( a.dec_comprate - 1 )
* ISNULL(b.dec_deduamt, 0) dec_corramt ,
a.dec_qty - ISNULL(b.dec_qty, 0) - ISNULL(b.dec_deduqty, 0) opr_qty ,
ISNULL(b.dec_pay, 0) dec_pay ,
ISNULL(b.dec_corrpay, 0) dec_corrpay ,
ISNULL(b.dec_deduqty, 0) dec_deduqty ,
ISNULL(b.dec_deduamt, 0) dec_deduamt ,
ISNULL(b.dec_qty, 0) dec_qty
FROM ctlm8686 a
LEFT JOIN ( SELECT dfeesum_no ,
SUM(dec_ramt) dec_pay ,
SUM(dec_corramt) dec_corrpay ,
SUM(dec_qty) dec_qty ,
SUM(CASE WHEN flag_dedu = '1' THEN dec_deduamt
ELSE 0
END) dec_deduamt ,
SUM(CASE WHEN flag_dedu = '1' THEN dec_deduqty
ELSE 0
END) dec_deduqty
FROM dfeepay_03
GROUP BY dfeesum_no
) b ON a.dfeesum_no = b.dfeesum_no
UNION ALL
SELECT a.dfeesum_no ,
a.dec_amt - ISNULL(b.dec_pay, 0) - ISNULL(b.dec_corrpay, 0)
- ISNULL(b.dec_deduamt, 0) dec_amt ,
a.dec_compamt - ISNULL(b.dec_pay, 0) - a.dec_comprate
* ISNULL(b.dec_deduamt, 0) dec_compamt ,
a.dec_corramt - ISNULL(b.dec_corrpay, 0) - ( a.dec_comprate - 1 )
* ISNULL(b.dec_deduamt, 0) dec_corramt ,
a.opr_qty - ISNULL(b.dec_qty, 0) - ISNULL(b.dec_deduqty, 0) opr_qty ,
ISNULL(b.dec_pay, 0) dec_pay ,
ISNULL(b.dec_corrpay, 0) dec_corrpay ,
ISNULL(b.dec_deduqty, 0) dec_deduqty ,
ISNULL(b.dec_deduamt, 0) dec_deduamt ,
ISNULL(b.dec_qty, 0) dec_qty
FROM dfeeapp_03 a
LEFT JOIN ( SELECT dfeesum_no ,
SUM(dec_ramt) dec_pay ,
SUM(dec_corramt) dec_corrpay ,
SUM(dec_qty) dec_qty ,
SUM(CASE WHEN flag_dedu = '1' THEN dec_deduamt
ELSE 0
END) dec_deduamt ,
SUM(CASE WHEN flag_dedu = '1' THEN dec_deduqty
ELSE 0
END) dec_deduqty
FROM dfeepay_03
GROUP BY dfeesum_no
) b ON a.dfeesum_no = b.dfeesum_no

  返回结果集有1433891行,其中

  SELECT COUNT(*) FROM dfeepay_03 --1103914
  SELECT COUNT(*) FROM ctlm8686 --1131586
  SELECT COUNT(*) FROM dfeeapp_03--302305

  上述SQL脚本中,子查询是相同的,即对子查询进行了两次扫描,可以考虑先让dfeeapp_03和ctlm8686union all,再left join dfeepay_03 。同时,对于子查询,先让dfeepay_03 表先查询出flag_dedu = '1'的数据,就不用再进行case when判断了。

  改写后的SQL如下

SELECT  a.dfeesum_no ,
a.opr_amt - ISNULL(b.dec_pay, 0) - ISNULL(b.dec_corrpay, 0)
- ISNULL(b.dec_deduamt, 0) dec_amt ,
a.dec_camt - ISNULL(b.dec_pay, 0) - a.dec_comprate
* ISNULL(b.dec_deduamt, 0) dec_compamt ,
a.dec_ramt - ISNULL(b.dec_corrpay, 0) - ( a.dec_comprate - 1 )
* ISNULL(b.dec_deduamt, 0) dec_corramt ,
a.dec_qty - ISNULL(b.dec_qty, 0) - ISNULL(b.dec_deduqty, 0) opr_qty ,
ISNULL(b.dec_pay, 0) dec_pay ,
ISNULL(b.dec_corrpay, 0) dec_corrpay ,
ISNULL(b.dec_deduqty, 0) dec_deduqty ,
ISNULL(b.dec_deduamt, 0) dec_deduamt ,
ISNULL(b.dec_qty, 0) dec_qty
FROM ( SELECT a.dfeesum_no ,
a.opr_amt ,
a.dec_camt ,
a.dec_comprate ,
a.dec_ramt ,
a.dec_qty
FROM ctlm8686 a
UNION ALL
SELECT a.dfeesum_no ,
a.dec_amt ,
a.dec_compamt ,
a.dec_comprate ,
a.dec_corramt ,
a.opr_qty
FROM dfeeapp_03 a
) a
LEFT JOIN ( SELECT dfeesum_no ,
SUM(dec_ramt) dec_pay ,
SUM(dec_corramt) dec_corrpay ,
SUM(dec_qty) dec_qty ,
SUM(dec_deduamt) dec_deduamt,
SUM(dec_deduqty) dec_deduqty
FROM dfeepay_03
WHERE flag_dedu = '1'
GROUP BY dfeesum_no
) b ON a.dfeesum_no = b.dfeesum_no

  跑这个视图的查询语句,从原来的一分半钟降到一分钟,对于整个SQL而言,则从原来跑几分钟的直接10S出结果。

通过调整表union all的顺序优化SQL的更多相关文章

  1. sql语句优化SQL Server

    MS   SQL   Server查询优化方法查询速度慢的原因很多,常见如下几种 1.没有索引或者没有用到索引(这是查询慢最常见的问题,是程序设计的缺陷)          2.I/O吞吐量小,形成了 ...

  2. mysql优化SQL语句的一般步骤及常用方法

    一.优化SQL语句的一般步骤 1. 通过show status命令了解各种SQL的执行频率 mysqladmin extended-status 或: show [session|global]sta ...

  3. 转载 50种方法优化SQL Server数据库查询

    原文地址 http://www.cnblogs.com/zhycyq/articles/2636748.html 50种方法优化SQL Server数据库查询 查询速度慢的原因很多,常见如下几种: 1 ...

  4. MySQL查询不使用索引汇总 + 如何优化sql语句

    不使用索引原文 : http://itlab.idcquan.com/linux/MYSQL/918330.html MySQL查询不使用索引汇总 众所周知,增加索引是提高查询速度的有效途径,但是很多 ...

  5. 浅谈MySQL中优化sql语句查询常用的30种方法 - 转载

    浅谈MySQL中优化sql语句查询常用的30种方法 1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中使 ...

  6. mysql优化sql语句

    mysql优化sql语句   常见误区   www.2cto.com   误区1:   count(1)和count(primary_key) 优于 count(*)   很多人为了统计记录条数,就使 ...

  7. 数据库优化 - SQL优化

    前面一篇文章从实例的角度进行数据库优化,通过配置一些参数让数据库性能达到最优.但是一些"不好"的SQL也会导致数据库查询变慢,影响业务流程.本文从SQL角度进行数据库优化,提升SQ ...

  8. 转载 数据库优化 - SQL优化

    判断问题SQL判断SQL是否有问题时可以通过两个表象进行判断: 系统级别表象CPU消耗严重IO等待严重页面响应时间过长应用的日志出现超时等错误可以使用sar命令,top命令查看当前系统状态. 也可以通 ...

  9. MySql(五)SQL优化-优化SQL语句的一般步骤

    MySql(五)SQL优化-优化SQL语句的一般步骤 一.优化SQL语句的一般步骤 1.1 通过show status命令了解各种SQL的执行频率 1.2 定位执行效率较低的SQL语句 1.3 通过e ...

随机推荐

  1. 创建用于自定义SharePoint解决方案部署的Visual Studio项目

    转:http://soft.zdnet.com.cn/software_zone/2007/0903/488083.shtml 在基于SharePoint的开发中,我们通常会在WSS的TEMPLATE ...

  2. javascript在alert()出现中文乱码

    今天在写jquery代码时,alert()总是出现中文乱码 琢磨了好一会儿,在网上查的资料是html页面上设置charset为GB2312 <meta charset="GB2312& ...

  3. 关于 RecastNavigation 寻路结果异常的问题。

    由于我们的项目采用的寻路解决方案是:客户端使用 unity 原生的寻路系统,服务器采用 RecastNavigation 系统,而服务器的寻路数据来自于从 unity 导出的,所以理论上两边的寻路结果 ...

  4. ios 中的半屏幕底部弹出框

    static UIView *modalView;if (modalView) { [modalView removeFromSuperview]; modalView = nil; return; ...

  5. Asp.Net Design Pattern Studynotes -- Part1

    Asp.Net Design Pattern Studynotes -- Part1 let's start with an exampleto entry amazing OO world ! le ...

  6. 手机变为电脑的摄像头,使像素高清起来-使用DroidCam

    你是不是已经在嫌弃电脑自带的摄像头的渣渣像素呢? 今天给大家安利一个方法:将手机摄像头设置为电脑的摄像头,让像素高清起来,对于搞图像的同志们真是福音啊,尤其是做人脸识别的时候. 方法有很多种,我推荐我 ...

  7. Spring基于注解的Cache支持

    Spring为我们提供了几个注解来支持Spring Cache.其核心主要是@Cacheable和@CacheEvict.使用@Cacheable标记的方法在执行后Spring Cache将缓存其返回 ...

  8. kernel笔记:TCP参数

    http://blog.chinaunix.net/uid-27119491-id-3346430.html 本文将介绍网络连接建立的过程.收发包流程,以及其中应用层.tcp层.ip层.设备层和驱动层 ...

  9. Cocos2d-x在win32,android和IOS下的文件读写问题

    最近在学习和使用Cocos2d-x框架,虽然说的是跨平台,但是在用VS进行开发,然后移植到android或IOS下,也可能会出现各种问题,需要做细微的调整. 例如我在做文件读写操作的时候,很可能在wi ...

  10. linux shell wc 命令

    1. 语法与选项 Short Option Long Option Option Description -c –bytes print the byte counts -m –chars print ...