废话不多说,直接上sql

SELECT  top 1  B.CREW_ID, E.CREW_NAME,C.OFFBLK,C.ONBLK,dbo.PEK_OPS_Date(A.STD) as STD
FROM dbo.FLIGHTS A
LEFT OUTER JOIN
(SELECT DISTINCT TASK_ID, CREW_ID
FROM dbo.CREW_TASK
) B ON A.COCKPIT_CREW_GROUP = B.TASK_ID
LEFT OUTER JOIN dbo.FLIGHTS_CREW_REPORT C ON A.FLTID = C.FLTID
LEFT JOIN CREW_INFO E ON B.CREW_ID = E.CREW_ID
LEFT JOIN FLIGHTS_STC F ON A.STC = F.IATA_CODE
WHERE (A.COCKPIT_CREW_GROUP > 0) AND (A.STATUS='ATA')
AND F.RATIO = 1 AND NOT (A.AC LIKE '%--%')
AND B.CREW_ID = ISNULL(60, B.CREW_ID) AND C.OFFBLK is not null AND C.ONBLK is not null
AND C.CREW_LEFT is not null AND C.CREW_RIGHT is not null
ORDER BY A.STD desc

执行计划如下:

执行时间: 16秒、

分析:

嵌套循环之前,进行了排序操作,驱动表CREW_TASK 单表数据量300232。去重排序之后29w+。FLIGHTS 表单表44w+,这里不走hash 的原因是因为top1导致。故去掉 TOP 1 限制语句

SELECT   B.CREW_ID, E.CREW_NAME,C.OFFBLK,C.ONBLK,dbo.PEK_OPS_Date(A.STD) as STD
FROM dbo.FLIGHTS A
LEFT OUTER JOIN
(SELECT DISTINCT TASK_ID, CREW_ID
FROM dbo.CREW_TASK
) B ON A.COCKPIT_CREW_GROUP = B.TASK_ID
LEFT OUTER JOIN dbo.FLIGHTS_CREW_REPORT C ON A.FLTID = C.FLTID
LEFT JOIN CREW_INFO E ON B.CREW_ID = E.CREW_ID
LEFT JOIN FLIGHTS_STC F ON A.STC = F.IATA_CODE
WHERE (A.COCKPIT_CREW_GROUP > 0) AND (A.STATUS='ATA')
AND F.RATIO = 1 AND NOT (A.AC LIKE '%--%')
AND B.CREW_ID = ISNULL(60, B.CREW_ID) AND C.OFFBLK is not null AND C.ONBLK is not null
AND C.CREW_LEFT is not null AND C.CREW_RIGHT is not null
ORDER BY A.STD desc

执行计划:

执行时间:

分析:很明显hash走了hash 匹配,可见在双大表情况下,hash 匹配返回5000多行比嵌套循环返回一条要快得多。

方向明确,那么怎么取上述第一条数据呢?这个时候用到 TOP percent,也就是返回结果集的一个比例值,而不是 top 1 第一条数据:

sql如下:

SELECT  top 100 percent B.CREW_ID, E.CREW_NAME,C.OFFBLK,C.ONBLK,dbo.PEK_OPS_Date(A.STD) as STD
FROM dbo.FLIGHTS A
LEFT OUTER JOIN
(SELECT DISTINCT TASK_ID, CREW_ID
FROM dbo.CREW_TASK
) B ON A.COCKPIT_CREW_GROUP = B.TASK_ID
LEFT OUTER JOIN dbo.FLIGHTS_CREW_REPORT C ON A.FLTID = C.FLTID
LEFT JOIN CREW_INFO E ON B.CREW_ID = E.CREW_ID
LEFT JOIN FLIGHTS_STC F ON A.STC = F.IATA_CODE
WHERE (A.COCKPIT_CREW_GROUP > 0) AND (A.STATUS='ATA')
AND F.RATIO = 1 AND NOT (A.AC LIKE '%--%')
AND B.CREW_ID = ISNULL(60, B.CREW_ID) AND C.OFFBLK is not null AND C.ONBLK is not null
AND C.CREW_LEFT is not null AND C.CREW_RIGHT is not null
ORDER BY A.STD desc

执行时间 ,返回100%的结果集

怎么返回第一条?很简单,我返回1%的结果集如下:

SELECT  top 1 percent B.CREW_ID, E.CREW_NAME,C.OFFBLK,C.ONBLK,dbo.PEK_OPS_Date(A.STD) as STD
FROM dbo.FLIGHTS A
LEFT OUTER JOIN
(SELECT DISTINCT TASK_ID, CREW_ID
FROM dbo.CREW_TASK
) B ON A.COCKPIT_CREW_GROUP = B.TASK_ID
LEFT OUTER JOIN dbo.FLIGHTS_CREW_REPORT C ON A.FLTID = C.FLTID
LEFT JOIN CREW_INFO E ON B.CREW_ID = E.CREW_ID
LEFT JOIN FLIGHTS_STC F ON A.STC = F.IATA_CODE
WHERE (A.COCKPIT_CREW_GROUP > 0) AND (A.STATUS='ATA')
AND F.RATIO = 1 AND NOT (A.AC LIKE '%--%')
AND B.CREW_ID = ISNULL(60, B.CREW_ID) AND C.OFFBLK is not null AND C.ONBLK is not null
AND C.CREW_LEFT is not null AND C.CREW_RIGHT is not null
ORDER BY A.STD desc

执行时间:,很明显返回的是1%的结果集

返回0.01的结果集:

SELECT  top 0.01 percent B.CREW_ID, E.CREW_NAME,C.OFFBLK,C.ONBLK,dbo.PEK_OPS_Date(A.STD) as STD
FROM dbo.FLIGHTS A
LEFT OUTER JOIN
(SELECT DISTINCT TASK_ID, CREW_ID
FROM dbo.CREW_TASK
) B ON A.COCKPIT_CREW_GROUP = B.TASK_ID
LEFT OUTER JOIN dbo.FLIGHTS_CREW_REPORT C ON A.FLTID = C.FLTID
LEFT JOIN CREW_INFO E ON B.CREW_ID = E.CREW_ID
LEFT JOIN FLIGHTS_STC F ON A.STC = F.IATA_CODE
WHERE (A.COCKPIT_CREW_GROUP > 0) AND (A.STATUS='ATA')
AND F.RATIO = 1 AND NOT (A.AC LIKE '%--%')
AND B.CREW_ID = ISNULL(60, B.CREW_ID) AND C.OFFBLK is not null AND C.ONBLK is not null
AND C.CREW_LEFT is not null AND C.CREW_RIGHT is not null
ORDER BY A.STD desc

执行时间:   已经达到要求。

注意:这里返回的是结果集的 百分比,虽然现在满足取第一条的要求,但是是随数据量增大,可能会多条, 故,外面包一层,取TOP 1 这样能保证只取一条。

select top 1 AA.* from (
SELECT top 1 percent B.CREW_ID, E.CREW_NAME,C.OFFBLK,C.ONBLK,dbo.PEK_OPS_Date(A.STD) as STD
FROM dbo.FLIGHTS A
LEFT OUTER JOIN
(SELECT DISTINCT TASK_ID, CREW_ID
FROM dbo.CREW_TASK
) B ON A.COCKPIT_CREW_GROUP = B.TASK_ID
LEFT OUTER JOIN dbo.FLIGHTS_CREW_REPORT C ON A.FLTID = C.FLTID
LEFT JOIN CREW_INFO E ON B.CREW_ID = E.CREW_ID
LEFT JOIN FLIGHTS_STC F ON A.STC = F.IATA_CODE
WHERE (A.COCKPIT_CREW_GROUP > 0) AND (A.STATUS='ATA')
AND F.RATIO = 1 AND NOT (A.AC LIKE '%--%')
AND B.CREW_ID = ISNULL(60, B.CREW_ID) AND C.OFFBLK is not null AND C.ONBLK is not null
AND C.CREW_LEFT is not null AND C.CREW_RIGHT is not null
ORDER BY A.STD desc )AA

执行时间:

收工!

巧用top percent优化top 1的更多相关文章

  1. SQL优化系列(二)- 优化Top SQL

    优化最耗资源的N条SQL语句 如何从SGA或者AWR中找出最消耗资源的SQL, 例如最慢的20条SQL, 然后逐条优化? SQL自动优化工具SQL Tuning Expert Pro for Orac ...

  2. 33.allegro中Autosilk top, Silkscreen top 和Assembly top三个什么区别(转)

    Autosilk top, Silkscreen top 和Assembly top Autosilk top:最后出gerber的时候,自动生成的丝印层.会自动调整丝印位置,以及碰到阻焊开窗的地方, ...

  3. allegro中Autosilk top, Silkscreen top 和Assembly top三个什么区别(转)

    allegro中Autosilk top, Silkscreen top 和Assembly top三个什么区别(转) Autosilk top, Silkscreen top 和Assembly t ...

  4. 获取分组后的TOP 1和TOP N记录

    MySQL获取分组后的TOP 1和TOP N记录 有时会碰到一些需求,查询分组后的最大值,最小值所在的整行记录或者分组后的top n行的记录,在一些别的数据库可能有窗口函数可以方面的查出来,但是MyS ...

  5. css3的transform变换scale和translate等影响jQuery的position().top和offset().top

    css3的transform变换scale和translate等影响jQuery的position().top和offset().top

  6. 每天进步一点点------Allegro中Autosilk top, Silkscreen top 和Assembly top三个什么区别

    Autosilk top:最后出gerber的时候,自动生成的丝印层.会自动调整丝印位置,以及碰到阻焊开窗的地方,丝印会自动消失,避免露锡的地方涂上丝印(一般画丝印层的时候,焊盘上不会画上丝印,所以过 ...

  7. 数据库学习笔记3 基本的查询流 2 select lastname+','+firstname as fullname order by lastname+','+firstname len() left() stuff() percent , select top(3) with ties

    数据库学习笔记3 基本的查询流 2   order by子句对查询结果集进行排序 多列和拼接 多列的方式就很简单了 select firstname,lastname from person.pers ...

  8. (转)top关键字与top表达式(SQLServer)

    SQLServer 中,top也很有用,例如查询部分数据,还可以用表达式.其语法如下: SELECT TOP number|percent column_name(s) FROM table_name ...

  9. jquery的offset().top 和position().top 详解 和如何用js实现

    1 jquery定义: offset().top 相对于当前文档的坐标(的高度) ps:包括滚动条卷去的高度 position().top 返回的是相对于其定位的祖辈元素的坐标(的高度) ps:包括滚 ...

随机推荐

  1. “网红架构师”解决你的Ceph 运维难题

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由Tstack发表于云+社区专栏 本文为长篇连续剧,将分多个篇幅发表,主要介绍了从动手部署环境到后期运营故障处理过程中常见的问题,内容由 ...

  2. 海量数据处理之Tire树(字典树)

    参考博文:http://blog.csdn.net/v_july_v/article/details/6897097 第一部分.Trie树 1.1.什么是Trie树 Trie树,即字典树,又称单词查找 ...

  3. offsetHeight,scrollHeight,clientHeight,scrollTop以及pageX,clientX,offsetX,screenX,offsetLeft,style.left等的区别以及使用详解

    一.写在前面 在阅读本文前,希望大家能针对每个属性亲手测试,网上现有的大量相关博客都有不等的概念错误,毕竟亲手实践才能更好的掌握这些概念. 1.pageX,clientX,screenX与offset ...

  4. Jquery自定义动画与动画队列

    animate:自定义动画 $(selector).animate({params},[speed],[easing],[callback]); params:要执行动画的css属性,它是一个对象可以 ...

  5. order by与索引(转载)

    order by与索引   ORDER BY 通常会有两种实现方法,一个是利用有序索引自动实现,也就是说利用有序索引的有序性就不再另做排序操作了.另一个是把结果选好之后再排序. 用有序索引这种,当然是 ...

  6. 简单的SpringMVC经典案例

    主题:构建一个基于SpringMVC的HelloWord Web 项目 目的:快速体验什么是SpringMVC 方案: 1.创建工程,命名:SpringMVC 2.导包 3.在SRC下添加spring ...

  7. 在JAVA中封装JSONUtil工具类及使用

    在JAVA中用json-lib-2.3-jdk15.jar包中提供了JSONObject和JSONArray基类,用于JSON的序列化和反序列化的操作.但是我们更习惯将其进一步封装,达到更好的重用. ...

  8. Java虚拟机 - 语法糖

    [深入Java虚拟机]之六:Java语法糖 语法糖(Syntactic Sugar),也称糖衣语法,是由英国计算机学家Peter.J.Landin发明的一个术语,指在计算机语言中添加的某种语法,这种语 ...

  9. SpringBoot拦截器中无法注入bean的解决方法

    SpringBoot拦截器中无法注入bean的解决方法 在使用springboot的拦截器时,有时候希望在拦截器中注入bean方便使用 但是如果直接注入会发现无法注入而报空指针异常 解决方法: 在注册 ...

  10. python序列函数

    zip:序列并行处理 >>> name=['ghostwu','wukong','bajie'] >>> age=['] >>> sex=['ma ...