IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> 记一次生产sql优化 -> 正文阅读

[大数据]记一次生产sql优化

总结优化思路
1分析当前业务
2定位慢查询arthas
3分析查询参数,优化查询参数 ,优化返回结果
4explan 分析慢查询 根据sql 分解sql,看哪一个子查询慢,优化索引,优化查询顺序结构等
5以上都不行 前期就应该建立分库分表 或者使用ck nosql 进行查询

arthas 分析结果如下

[arthas@25356]$ trace com.rfca.dao.mapper.ParkingMapper QueryLatePhoto
Press Q or Ctrl+C to abort.
Affect(class count: 2 , method count: 1) cost in 140 ms, listenerId: 13
`---ts=2022-05-19 13:09:39;thread_name=pool-4-thread-6;id=67;is_daemon=false;priority=5;TCCL=org.apache.catalina.loader.ParallelWebappClassLoader@62cc7715
    `---[28.034673ms] com.sun.proxy.$Proxy120:QueryLatePhoto()

`---ts=2022-05-19 13:09:50;thread_name=pool-4-thread-4;id=65;is_daemon=false;priority=5;TCCL=org.apache.catalina.loader.ParallelWebappClassLoader@62cc7715
    `---[31.923302ms] com.sun.proxy.$Proxy120:QueryLatePhoto()

`---ts=2022-05-19 13:10:00;thread_name=pool-4-thread-5;id=66;is_daemon=false;priority=5;TCCL=org.apache.catalina.loader.ParallelWebappClassLoader@62cc7715
    `---[61.771667ms] com.sun.proxy.$Proxy120:QueryLatePhoto()

[arthas@25356]$ 
[arthas@25356]$ trace com.rfca.dao.mapper.ParkingMapper QueryLongOccupys
Press Q or Ctrl+C to abort.
Affect(class count: 2 , method count: 1) cost in 138 ms, listenerId: 14
`---ts=2022-05-19 13:10:49;thread_name=pool-4-thread-4;id=65;is_daemon=false;priority=5;TCCL=org.apache.catalina.loader.ParallelWebappClassLoader@62cc7715
    `---[64.901587ms] com.sun.proxy.$Proxy120:QueryLongOccupys()

`---ts=2022-05-19 13:11:23;thread_name=pool-4-thread-5;id=66;is_daemon=false;priority=5;TCCL=org.apache.catalina.loader.ParallelWebappClassLoader@62cc7715
    `---[41.786277ms] com.sun.proxy.$Proxy120:QueryLongOccupys()

[arthas@25356]$ trace com.rfca.dao.mapper.ParkingMapper QueryLongEmptys
Press Q or Ctrl+C to abort.
Affect(class count: 2 , method count: 1) cost in 142 ms, listenerId: 15
`---ts=2022-05-19 13:11:54;thread_name=pool-4-thread-3;id=64;is_daemon=false;priority=5;TCCL=org.apache.catalina.loader.ParallelWebappClassLoader@62cc7715
    `---[6.182256ms] com.sun.proxy.$Proxy120:QueryLongEmptys()

[arthas@25356]$ trace com.rfca.dao.mapper.ParkingMapper QuerySys
Press Q or Ctrl+C to abort.
Affect(class count: 2 , method count: 1) cost in 144 ms, listenerId: 16
`---ts=2022-05-19 13:12:25;thread_name=pool-4-thread-4;id=65;is_daemon=false;priority=5;TCCL=org.apache.catalina.loader.ParallelWebappClassLoader@62cc7715
    `---[18.25196ms] com.sun.proxy.$Proxy120:QuerySys()

[arthas@25356]$ trace com.rfca.dao.mapper.ParkingMapper historicalpaymentrate
Press Q or Ctrl+C to abort.
Affect(class count: 2 , method count: 1) cost in 142 ms, listenerId: 17
`---ts=2022-05-19 13:13:04;thread_name=pool-4-thread-3;id=64;is_daemon=false;priority=5;TCCL=org.apache.catalina.loader.ParallelWebappClassLoader@62cc7715
    `---[4663.98636ms] com.sun.proxy.$Proxy120:historicalpaymentrate()

[arthas@25356]$ trace com.rfca.dao.mapper.ParkingMapper paymentrateByTime
Press Q or Ctrl+C to abort.
Affect(class count: 2 , method count: 1) cost in 140 ms, listenerId: 18
`---ts=2022-05-19 13:13:47;thread_name=pool-4-thread-9;id=6a;is_daemon=false;priority=5;TCCL=org.apache.catalina.loader.ParallelWebappClassLoader@62cc7715
    `---[9.511763ms] com.sun.proxy.$Proxy120:paymentrateByTime()

`---ts=2022-05-19 13:14:16;thread_name=pool-4-thread-8;id=69;is_daemon=false;priority=5;TCCL=org.apache.catalina.loader.ParallelWebappClassLoader@62cc7715
    `---[6.436025ms] com.sun.proxy.$Proxy120:paymentrateByTime()

由以上结果分析可知
trace com.rfca.dao.mapper.ParkingMapper historicalpaymentrate

这个类的历史查询接口返回需要4秒多 需要优化 ,

QueryChargeRate11 方法需要7秒需要优化

原7秒的sql

<!--        SELECT-->
<!--        t_parking_record.parkinglotid AS id,SUM(t_charge_record.money) AS VALUE ,SUM(t_charge_record.receivable) AS total-->
<!--        FROM  t_charge_record LEFT JOIN t_parking_record ON  t_charge_record.parkingrecordid = t_parking_record.id-->
<!--        LEFT JOIN t_parkinglot ON t_parkinglot.id = t_parking_record.parkinglotid-->
<!--        where-->
<!--        t_parking_record.state > -1-->
<!--        <if test="start_date !=null">-->
<!--            and t_charge_record.modifytime &gt; #{start_date}-->
<!--        </if>-->
<!--        <if test="list !=null and list.size > 0 ">-->
<!--            and t_parkinglot.parkinglotno in-->
<!--            <foreach item="item" index="index" collection="list" open="("-->
<!--                     separator="," close=")">-->
<!--                #{item}-->
<!--            </foreach>-->
<!--        </if>-->
<!--        GROUP BY t_parking_record.parkinglotid-->

优化思路,通过小表驱动大表的思路先把查询结果找出在进行join

    SELECT  t_parking_record.parkinglotid AS id,
        SUM(b.money) AS VALUE ,
        SUM(b.receivable) AS total
        FROM (SELECT  a.parkingrecordid,a.money,a.receivable FROM t_charge_record AS a WHERE a.modifytime &gt; #{start_date}) AS b
        LEFT JOIN t_parking_record ON  b.parkingrecordid = t_parking_record.id
        LEFT JOIN t_parkinglot ON t_parkinglot.id = t_parking_record.parkinglotid
        WHERE
        t_parking_record.state > -1

        GROUP BY t_parking_record.parkinglotid

优化后 505ms

4秒的原sql

  SELECT b.`parkinglotid` as id,SUM(receivable) AS total,SUM(proceeds) AS proceeds FROM ( SELECT t.id  FROM  t_parkinglot t WHERE 1=1
        <if test="list !=null and list.size > 0 ">
            and t.parkinglotno in
            <foreach item="item" index="index" collection="list" open="("
                     separator="," close=")">
                #{item}
            </foreach>
        </if>
        )AS a
        LEFT JOIN t_parking_record b ON  a.id = b.parkinglotid
        AND b.state > -1
        <if test="start_date !=null">
            and b.outtime &gt; #{start_date} and b.outtime &lt; #{end_date}
        </if>
        GROUP BY b.parkinglotid

这个sql慢的原始是查询了半年的时间,扫描行数2千万行,又因为使用GROUP BY sum等操作没有使用索引 索引 使用索引覆盖原理 添加索引 outtime state parkinglotid receivable proceeds ,
条件优化
直接使用 parkinglotid 查询没有使用 parkinglotno
优化后 814 ms

这种方式如果还是不行,查询结果太大的话直接使用
使用 SQL_BIG_RESULT 进行优化 直接走文件排序 少了内存到 文件的复制操作

如果上述结果还是很慢
扩展
5以上都不行 前期就应该建立分库分表 或者使用ck nosql 进行查询

本次优化结果性能提升 90%

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-05-24 18:15:37  更:2022-05-24 18:16:52 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 3:49:53-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码