Mysql分区表 sql优化

      随着公司业务发展,数据量越来越大,查询效率变低,BI组优化了订单表结构为分区表,以订单的支付时间作分区字段,一天为周期做了分区。通过查询条件加上分区条件,减少扫表行数,性能有了很大的提升。

示例:

 SELECT * FROM `order` WHERE receiverName="李"

这条语句用explain解释 :扫表34W行+。查询时间30ms,数据传输时间5535ms。数据传输很慢。加上分区字段后 ,如下所示

 SELECT * FROM `order` WHERE receiverName="李" AND payTime>DATE_ADD(CURRENT_DATE,INTERVAL -1 DAY) 

执行explain,结果如下:扫表4812行。查询时间24ms,数据传输时间55ms。数据量降低,传输耗时变短。性能提升很大。

索引字段和分区表字段一起查询,sql如下:

EXPLAIN SELECT * FROM `order` WHERE receiverName="李" AND payTime>DATE_ADD(CURRENT_DATE,INTERVAL -1 DAY) AND orderId="xxxxxx"

执行explain,结果如下:扫表1行。查询时间27ms,数据传输时间1ms。速度更快。

 

小结(自己理解,可能有误):查询类的sql优化无论是建索引还是加限制条件,还是连表代替子查询,根本目的都是减少扫表行数(减少查询时间),精确搜索(用select 字段名代替 select * ),减少数据传输时间。sql优化也可以从这个角度入手。通过各种手段减少扫表行数,减少返回结果。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值