SQL有外连接的时候注意过滤条件位置

简介: 发现了一个SQL确实跑得慢。该SQL 如下[html] view plaincopyprint?select *    from (select u.

发现了一个SQL确实跑得慢。该SQL 如下

[html]  view plain copy print ?
  1. select *  
  2.   from (select u.NAME UniversityName,  
  3.                u.id UniversityId,  
  4.                count(a.SIGNUPNUMBER) playercnt  
  5.           from T_B_UNIVERSITY u  
  6.           left join T_D_EDUCATION e  
  7.             on e.UNIVERSITY_ID = u.id  
  8.           left join T_D_VIDEO_PLAYER a  
  9.             on a.USER_ID = e.user_id  
  10.            and e.ISDEFAULT = 1  
  11.            and e.ISVALID = 1  
  12.            and a.AUDITSTATUS = 1  
  13.            and a.ISVALID = 1  
  14.           left join T_D_USER c  
  15.             on a.USER_ID = c.id  
  16.            and c.ISVALID = 1  
  17.          where u.REGION_CODE like '43%'  
  18.          group by u.NAME, u.id)  
  19.  order by playercnt desc;  


执行计划如下

 

[html]  view plain copy print ?
  1. 执行计划  
  2. ----------------------------------------------------------  
  3. Plan hash value: 3938743742  
  4.   
  5. --------------------------------------------------------------------------------------------  
  6. | Id  | Operation               | Name             | Rows  | Bytes | Cost (%CPU)| Time     |  
  7. --------------------------------------------------------------------------------------------  
  8. |   0 | SELECT STATEMENT        |                  |   142 | 10366 |   170   (3)| 00:00:03 |  
  9. |   1 |  SORT ORDER BY          |                  |   142 | 10366 |   170   (3)| 00:00:03 |  
  10. |   2 |   HASH GROUP BY         |                  |   142 | 10366 |   170   (3)| 00:00:03 |  
  11. |*  3 |    HASH JOIN RIGHT OUTER|                  |   672 | 49056 |   168   (2)| 00:00:03 |  
  12. |*  4 |     TABLE ACCESS FULL   | T_D_USER         |   690 |  5520 |     5   (0)| 00:00:01 |  
  13. |   5 |     NESTED LOOPS OUTER  |                  |   672 | 43680 |   162   (1)| 00:00:02 |  
  14. |*  6 |      HASH JOIN OUTER    |                  |   672 | 37632 |    14   (8)| 00:00:01 |  
  15. |*  7 |       TABLE ACCESS FULL | T_B_UNIVERSITY   |    50 |  2050 |     8   (0)| 00:00:01 |  
  16. |   8 |       TABLE ACCESS FULL | T_D_EDUCATION    |   672 | 10080 |     5   (0)| 00:00:01 |  
  17. |   9 |      VIEW               |                  |     1 |     9 |     0   (0)| 00:00:01 |  
  18. |* 10 |       FILTER            |                  |       |       |            |          |  
  19. |* 11 |        TABLE ACCESS FULL| T_D_VIDEO_PLAYER |     1 |    15 |     3   (0)| 00:00:01 |  
  20. --------------------------------------------------------------------------------------------  
  21.   
  22. Predicate Information (identified by operation id):  
  23. ---------------------------------------------------  
  24.   
  25.    3 - access("A"."USER_ID"="C"."ID"(+))  
  26.    4 - filter("C"."ISVALID"(+)=1)  
  27.    6 - access("E"."UNIVERSITY_ID"(+)="U"."ID")  
  28.    7 - filter("U"."REGION_CODE" LIKE '43%')  
  29.   10 - filter("E"."ISVALID"=1 AND "E"."ISDEFAULT"=1)  
  30.   11 - filter("A"."USER_ID"="E"."USER_ID" AND "A"."AUDITSTATUS"=1 AND  
  31.               "A"."ISVALID"=1)  

 

大家能发现这个SQL 的问题吗? 这个 SQL 之所以跑得慢是因为开发人员把SQL的条件写错位置了

正确的写法应该是 下面这样的

[html]  view plain copy print ?
  1. select *  
  2.   from (select u.NAME UniversityName,  
  3.                u.id UniversityId,  
  4.                count(a.SIGNUPNUMBER) playercnt  
  5.           from T_B_UNIVERSITY u  
  6.           left join T_D_EDUCATION e  
  7.             on e.UNIVERSITY_ID = u.id  
  8.            and e.ISDEFAULT = 1  
  9.            and e.ISVALID = 1  
  10.           left join T_D_VIDEO_PLAYER a  
  11.             on a.USER_ID = e.user_id      
  12.            and a.AUDITSTATUS = 1  
  13.            and a.ISVALID = 1  
  14.           left join T_D_USER c  
  15.             on a.USER_ID = c.id  
  16.            and c.ISVALID = 1  
  17.          where u.REGION_CODE like '43%'  
  18.          group by u.NAME, u.id)  
  19.  order by playercnt desc;   


执行计划如下

 

[html]  view plain copy print ?
  1. 执行计划  
  2. ----------------------------------------------------------  
  3. Plan hash value: 2738827747  
  4.   
  5. ---------------------------------------------------------------------------------------------  
  6. | Id  | Operation                | Name             | Rows  | Bytes | Cost (%CPU)| Time     |  
  7. ---------------------------------------------------------------------------------------------  
  8. |   0 | SELECT STATEMENT         |                  |   142 | 11218 |    25  (16)| 00:00:01 |  
  9. |   1 |  SORT ORDER BY           |                  |   142 | 11218 |    25  (16)| 00:00:01 |  
  10. |   2 |   HASH GROUP BY          |                  |   142 | 11218 |    25  (16)| 00:00:01 |  
  11. |*  3 |    HASH JOIN RIGHT OUTER |                  |   301 | 23779 |    23   (9)| 00:00:01 |  
  12. |*  4 |     TABLE ACCESS FULL    | T_D_USER         |   690 |  5520 |     5   (0)| 00:00:01 |  
  13. |*  5 |     HASH JOIN RIGHT OUTER|                  |   301 | 21371 |    17   (6)| 00:00:01 |  
  14. |*  6 |      TABLE ACCESS FULL   | T_D_VIDEO_PLAYER |    78 |  1170 |     3   (0)| 00:00:01 |  
  15. |*  7 |      HASH JOIN OUTER     |                  |   301 | 16856 |    14   (8)| 00:00:01 |  
  16. |*  8 |       TABLE ACCESS FULL  | T_B_UNIVERSITY   |    50 |  2050 |     8   (0)| 00:00:01 |  
  17. |*  9 |       TABLE ACCESS FULL  | T_D_EDUCATION    |   301 |  4515 |     5   (0)| 00:00:01 |  
  18. ---------------------------------------------------------------------------------------------  
  19.   
  20. Predicate Information (identified by operation id):  
  21. ---------------------------------------------------  
  22.   
  23.    3 - access("A"."USER_ID"="C"."ID"(+))  
  24.    4 - filter("C"."ISVALID"(+)=1)  
  25.    5 - access("A"."USER_ID"(+)="E"."USER_ID")  
  26.    6 - filter("A"."AUDITSTATUS"(+)=1 AND "A"."ISVALID"(+)=1)  
  27.    7 - access("E"."UNIVERSITY_ID"(+)="U"."ID")  
  28.    8 - filter("U"."REGION_CODE" LIKE '43%')  
  29.    9 - filter("E"."ISDEFAULT"(+)=1 AND "E"."ISVALID"(+)=1)  


之前SQL要跑至少5秒以上,现在0.1秒能出结果。

 

各位童鞋,SQL 有外连接的时候,要注意过滤条件的位置,记住啦!!!

目录
相关文章
|
2月前
|
SQL 开发框架 .NET
ASP.NET连接SQL数据库:详细步骤与最佳实践指南ali01n.xinmi1009fan.com
随着Web开发技术的不断进步,ASP.NET已成为一种非常流行的Web应用程序开发框架。在ASP.NET项目中,我们经常需要与数据库进行交互,特别是SQL数据库。本文将详细介绍如何在ASP.NET项目中连接SQL数据库,并提供最佳实践指南以确保开发过程的稳定性和效率。一、准备工作在开始之前,请确保您
288 3
|
2月前
|
SQL 数据库 索引
SQL语句实现投影连接:方法与技巧详解
在SQL数据库查询中,投影和连接是两个核心概念
|
2月前
|
SQL Java 数据库连接
如何使用`DriverManager.getConnection()`连接数据库,并利用`PreparedStatement`执行参数化查询,有效防止SQL注入。
【10月更文挑战第6天】在代码与逻辑交织的世界中,我从一名数据库新手出发,通过不断探索与实践,最终成为熟练掌握JDBC的开发者。这段旅程充满挑战与惊喜,从建立数据库连接到执行SQL语句,再到理解事务管理和批处理等高级功能,每一步都让我对JDBC有了更深的认识。示例代码展示了如何使用`DriverManager.getConnection()`连接数据库,并利用`PreparedStatement`执行参数化查询,有效防止SQL注入。
137 5
|
2月前
|
SQL 数据库 决策智能
SQL语句实现投影连接详解
在SQL中,投影(Projection)和连接(Join)是数据查询和处理中非常重要的两个操作
|
2月前
|
SQL 存储 数据可视化
SQL 数据库大揭秘:连接数字世界的魔法桥梁
在数字化时代,数据如繁星般璀璨,而 SQL 数据库则像强大的引力场,有序汇聚、整理和分析这些数据。SQL 数据库是一个巨大的数字宝库,装满各行各业的“宝藏”。本文将带你探索 SQL 数据库在电商、金融、医疗和教育等领域的应用。例如,在电商中,它能精准推荐商品;在金融中,它是安全卫士,防范欺诈;在医疗中,它是健康管家,管理病历;在教育中,则是智慧导师,个性化教学。此外,还将介绍如何利用板栗看板等工具实现数据可视化,提升决策效率。
|
2月前
|
SQL 开发框架 .NET
ASP连接SQL数据库:从基础到实践
随着互联网技术的快速发展,数据库与应用程序之间的连接成为了软件开发中的一项关键技术。ASP(ActiveServerPages)是一种在服务器端执行的脚本环境,它能够生成动态的网页内容。而SQL数据库则是一种关系型数据库管理系统,广泛应用于各类网站和应用程序的数据存储和管理。本文将详细介绍如何使用A
96 3
|
2月前
|
SQL 数据库 索引
SQL语句实现投影连接:技巧与方法详解
在SQL数据库操作中,投影连接(Projection Join)是一种常见的数据查询技术,它结合了投影(Projection)和连接(Join)两种操作
|
2月前
|
SQL 存储 监控
串口调试助手连接SQL数据库的技巧与方法
串口调试助手是电子工程师和软件开发人员常用的工具,它能够帮助用户进行串口通信的调试和数据分析
|
2月前
|
SQL 数据库 索引
内连接(INNER JOIN)在SQL中的简单应用与技巧
在SQL查询中,内连接(INNER JOIN)是一种基本且常用的连接类型,用于从两个或多个表中检索匹配的记录
|
2月前
|
SQL 开发框架 .NET
ASP.NET连接SQL数据库:实现过程与关键细节解析an3.021-6232.com
随着互联网技术的快速发展,ASP.NET作为一种广泛使用的服务器端开发技术,其与数据库的交互操作成为了应用开发中的重要环节。本文将详细介绍在ASP.NET中如何连接SQL数据库,包括连接的基本概念、实现步骤、关键代码示例以及常见问题的解决方案。由于篇幅限制,本文不能保证达到完整的2000字,但会确保