国内最专业的IT技术学习网

Mysql数据库

当前位置:主页 > Mysql数据库 >

银河官网:记一次生产数据库sql优化案例--23秒优化到0.9秒

发布时间:2019/09/27标签:   优化      数据库      SQL    点击量:

原标题:银河官网:记一次生产数据库sql优化案例--23秒优化到0.9秒

新项目业务人员反馈说最近订单发放模块经常很卡,导致总是有锁的情况发生,在用慢查询和开启锁监控观察后发现实际上只是单条查询慢造成的阻塞锁,这里考虑先对单条查询做一下优化

一、优化前的表结构、数据量、SQL、执行计划、执行时间

1. 表结构

A表有90个字段,B表有140个字段。

记一次生产数据库sql优化案例--23秒优化到0.9秒

2. 数据量

select count(*) from A; 

--166713 

select count(*) from B; 

--220810 

3. sql

开启慢查询观察到慢sql如下,单条执行只取200条记录是在23秒左右。

select ob.id, ob.customer, ob.order_no1, ob.accountingitems_code, ob.insert_date, ob.weight,  

ob.volume, ob.qty, ob.project_code,ob.order_no2,ob.order_type1  

 from A as ob  

where ifnull(ob.project_code,'')<>'' and ifnull(ob.accountingitems_code,'')<>''  

and ob.if_cost_proof='N'  

and EXISTS (select 1 from B ol where ob.id=ol.order_base) limit 200; 

记一次生产数据库sql优化案例--23秒优化到0.9秒

4. 执行计划

思路

这两张表都是订单表,全国各地的每天大概会产生十万行左右,这里又是全扫,等后期达到上千万的数据就GG了。目前只是看到这个sql上的问题,先考虑exists部分做一下改写。

二、exists部分改写

select ob.id, ob.customer, ob.order_no1, ob.accountingitems_code, ob.insert_date, ob.weight,  

ob.volume, ob.qty, ob.project_code,ob.order_no2,ob.order_type1  

 from fsl_order_base as ob,fsl_order_base_line ol 

where ob.id=ol.order_base and ob.if_cost_proof='N' and 

ifnull(ob.project_code,'')<>'' and ifnull(ob.accountingitems_code,'')<>'' limit 200; 

执行时间:耗时1.8秒

对应的执行计划:

可以看到ob表走了主键索引

业务确认结果符合需求,那就在这基础上建一下索引吧!

三、ol表建索引

create index idx_obl_id on fsl_order_base_line(order_base); 

create index idx_ob_id_cost on fsl_order_base(id,if_cost_proof); 

加上去但实际上用不到这个索引,选择去掉

记一次生产数据库sql优化案例--23秒优化到0.9秒

四、查看执行时间和执行计划

耗时1.1秒,可惜执行计划还是走了全扫,在对ob表建了索引实际上也用不到,最终只在ol表建了索引。

版权信息Copyright © 银河官网 版权所有    ICP备案编号:鲁ICP备09013610号