原SQL:

select ta.serialno,
       ta.accepttime,
       ta.subsnumber,
       ta.subsname,
       ta.contactphone1,
       ta.servicecontent,
       ta.address,
       r.region_name,
       s.contactchannel_name,
       p.name,
       p.fullname,
       rownum
  from (select t.serialno,
               t.accepttime,
               t.subsnumber,
               t.subsname,
               t.contactphone1,
               t.servicecontent,
               t.address,
               t.contactchannel,
               t.srtypeid,
               t.partition_id_region
          FROM report_threed_problemprocess t,
               (select trim(t1.para) p1
                  FROM System_Parameters_t t1
                 WHERE t1.para_flag = 'OVER_GONGXINBYCL_TYPE') a,
               (SELECT trim(t2.para) p2
                  FROM System_Parameters_t t2
                 WHERE t2.para_flag = 'OVER_GONGXINBYCL_CHANNEL') b,
               (SELECT TRIM(t3.para) p3
                  FROM System_Parameters_t t3
                 WHERE t3.para_flag = 'OVER_96180_TYPE') c
         WHERE t.partition_id_month = uf_get_partition_month(201306)
           and t.accepttime>=to_date(201306||'01','yyyymmdd') and t.accepttime<add_months(to_date(201306||'01','yyyymmdd'),1)
           and t.partition_id_region in
               (SELECT rt.ioid_id0 region_id
                  FROM region_t rt
                 WHERE rt.region_level = 4
                   AND rt.ioid_id0 >= 1001
                   AND rt.ioid_id0 <= 1018)
           AND t.srtypeid IN (SELECT spp.srtype_id
                                FROM sdt_para_pro_com_tsnote spp
                               WHERE spp.pro_com_id =1025
                                 AND state = 1)
        AND ((substr(t.srtypeid, 1, 6) = a.p1 and t.contactchannel = b.p2) or
        (substr(t.srtypeid, 1, 6) = c.p3 and t.contactchannel = b.p2))
        ) ta --96180
 inner join sdt_para_contactchannel s
    on ta.contactchannel = s.contactchannel
 inner join sdt_servicerequesttype p
    on ta.srtypeid = p.srtypeid
 inner join region_t r
    on r.ioid_id0=ta.partition_id_region;

在数据库上的执行时间为:65.969s

改进后的SQL:

select ta.serialno,
       ta.accepttime,
       ta.subsnumber,
       ta.subsname,
       ta.contactphone1,
       ta.servicecontent,
       ta.address,
       (SELECT r.region_name FROM region_t r WHERE  r.ioid_id0=ta.partition_id_region)region_name,
       (SELECT s.contactchannel_name FROM sdt_para_contactchannel s WHERE ta.contactchannel = s.contactchannel) contactchannel_name,
       p.name,
       p.fullname,
       rownum
  from (select t.serialno,
               t.accepttime,
               t.subsnumber,
               t.subsname,
               t.contactphone1,
               t.servicecontent,
               t.address,
               t.contactchannel,
               t.srtypeid,
               t.partition_id_region
          FROM report_threed_problemprocess t
         WHERE t.partition_id_month = uf_get_partition_month(201306)
           and t.accepttime>=to_date(201306||'01','yyyymmdd') and t.accepttime<add_months(to_date(201306||'01','yyyymmdd'),1)
           AND t.srtypeid IN (SELECT spp.srtype_id FROM sdt_para_pro_com_tsnote spp
                               WHERE spp.pro_com_id =1025 AND state = 1)
        AND
        (
          (substr(t.srtypeid, 1, 6) =(select trim(t1.para) FROM System_Parameters_t t1 WHERE t1.para_flag = 'OVER_GONGXINBYCL_TYPE')
                and t.contactchannel =(SELECT trim(t2.para) p2 FROM System_Parameters_t t2 WHERE t2.para_flag = 'OVER_GONGXINBYCL_CHANNEL')
           )
           or
          (substr(t.srtypeid, 1, 6) =(SELECT TRIM(t3.para) p3 FROM System_Parameters_t t3 WHERE t3.para_flag = 'OVER_96180_TYPE')
           and t.contactchannel =(SELECT trim(t2.para) p2 FROM System_Parameters_t t2 WHERE t2.para_flag = 'OVER_GONGXINBYCL_CHANNEL')
          )
         )
  ) ta --96180
 inner join sdt_servicerequesttype p
    on ta.srtypeid = p.srtypeid;
   执行时长:9.17s

暂时记这么多。

关于SQL优化的一个小试例子的更多相关文章

  1. 简单聊聊TiDB中sql优化的一个规则---左连接消除(Left Out Join Elimination)

    我们看看 TiDB 一段代码的实现 --- 左外连接(Left Out Join)的消除; select 的优化一般是这样的过程: 在逻辑执行计划的优化阶段, 会有很多关系代数的规则, 需要将逻辑执行 ...

  2. 关于sql优化的一个小总结

    1.数据量大的时候,可以分多次查询2.有些数据的存储可以分主次表,此表存一些不常用的数据3.union all 比union效率要高4.尽量不要用distinct5.不返回不需要的行和列6.根据条件加 ...

  3. SQL优化 MySQL版 - 避免索引失效原则(二)

    避免索引失效原则(二) 注:继上一篇文章继续讲解: 避免索引失效原则(一)https://www.cnblogs.com/StanleyBlogs/p/10482048.html#4195062 作者 ...

  4. 聊聊sql优化的15个小技巧

    前言 sql优化是一个大家都比较关注的热门话题,无论你在面试,还是工作中,都很有可能会遇到. 如果某天你负责的某个线上接口,出现了性能问题,需要做优化.那么你首先想到的很有可能是优化sql语句,因为它 ...

  5. 关于SQL优化的辟谣

    列举一些关于 SQL 语句的谣言,避免一些生瓜蛋子面试的时候被另外一群生瓜蛋子的 SQL 优化宝典给坑了. 以下所有内容都是 SQL Server 中的,其他数据库只能参考和借鉴 一.全表扫描 全表扫 ...

  6. 基于MySQL 的 SQL 优化总结

    文章首发于我的个人博客,欢迎访问.https://blog.itzhouq.cn/mysql1 基于MySQL 的 SQL 优化总结 在数据库运维过程中,优化 SQL 是 DBA 团队的日常任务.例行 ...

  7. BATJ解决千万级别数据之MySQL 的 SQL 优化大总结

    引用 在数据库运维过程中,优化 SQL 是 DBA 团队的日常任务.例行 SQL 优化,不仅可以提高程序性能,还能减低线上故障的概率. 目前常用的 SQL 优化方式包括但不限于:业务层优化.SQL 逻 ...

  8. SQL优化基础 使用索引(一个小例子)

    按照本文操作和体会,会对sql优化有个基本最简单的了解,其他深入还需要更多资料和实践的学习: 1. 建表: 复制代码代码如下: create table site_user ( id int IDEN ...

  9. sql优化经典例子

    场景 我用的数据库是mysql5.6,下面简单的介绍下场景 课程表 create table Course( c_id int PRIMARY KEY, name varchar(10) ) 数据10 ...

随机推荐

  1. careercup-C和C++ 13.2

    13.2 浅析哈希表和STL map.对比哈希表和STL map.哈希表是怎么实现的?如果输入数据规模不大, 我们可以使用什么数据结构来代替哈希表. 解答 对比哈希表和STL map 在哈希表中,实值 ...

  2. 关于Android模拟器键盘不能使用的解决方法

    很多朋友遇到一个问题,自己搭建完了Android环境后,启动模拟器体验Android系统,但是发现不能使用键盘方便的输入内容,如下图: 同时,使用笔记本的键盘也无法输入内容,只能通过模拟器内置的输入法 ...

  3. MVC - 学习总目录

    MVC - 基础 MVC - HtmlHelper类 MVC - 路由 MVC - 身份验证 MVC - 模型验证 MVC - Ajax MVC - 布局

  4. 在javascript中关于submit和button提交表单区别

    submit是button的一个特例,也是button的一种,它把提交这个动作自动集成了,submit和button,二者都以按钮的形式展现,看起来都是按钮,所不同的是type属性和处发响应的事件上. ...

  5. 我的开发框架(WinForm)

    近来,看园子里,好多同学,展示自己工作中的开发框架,有的功能强大,有的短小精悍,我也来凑个热闹,望各位大侠指点一二. 一.指导思想 1.尽量减少程序员对数据库的依赖,或者说尽力少的写sql 语句.根据 ...

  6. MySQL创建/删除/清空表,添加/删除字段

    创建表: create table tablename (column_name column_type); create table table_name( id int not null auto ...

  7. LNMP一键安装包-CentOS 5/6下自动编译安装Nginx,MySQL,PHP

    适用环境: 系统支持:CentOS-5 (32bit/64bit).CentOS-6 (32bit/64bit) 内存要求:≥128M 安装了什么: 1.Nginx-1.2.0 2.MySQL 5.5 ...

  8. Elasticsearch 查询与过滤

    今天在给上级汇报工作的时候,被问到了这个问题,一时也没回到上来. 英文原文: https://www.elastic.co/guide/en/elasticsearch/guide/current/_ ...

  9. 详细讲解Android对自己的应用代码进行混淆加密防止反编译

    1.查看项目中有没有proguard.cfg. 2.如果没有那就看看这个文件中写的什么吧,看完后将他复制到你的项目中. -optimizationpasses 5 -dontusemixedcasec ...

  10. 【Slickflow学习】.NET开源工作流项目转换(二)

    第一次自己写博客文章,大家多多指教.写博客主要记录一下学习的过程,给初学者提供下参考,也留给自己做备忘. Slickflow .NET开源工作流-项目转换 上一篇文章里说了1.2版本的下载,下载解压后 ...