sql优化相关

  1. 添加索引,但是数据倾斜比较大的时候不适合加索引。
    比如is_delete字段,大部分是0,如果添加索引,回表次数很多,导致性能变差
  2. 产生临时表要消除临时表。
    • select s.* from p left join s on p.shop_id = s.id where s.is_delete != 1 AND p.type = 1 order by s.id desc

​ 会产生临时表。因为先从p表查出来符合条件的行记录,现在还不能排序,要和s表连到一起才能排序。连到一起产生的表就是临时表,在临时表上排完序才可以返回。

select s.* from p left join s on p.shop_id = s.id where s.is_delete != 1 AND p.type = 1 order by p.shop_id desc

​ 这样就不会产生临时表。因为可以直接在p表查出来,排好序,在进行联表,而此时联表的数据已经是所需要的数据,可以直接返回。

上面所述的p表就是驱动表。(永远用小结果集驱动大结果集)

当使用left join等关联查询时,若order by子句和group by子句都来自于从表时会产生临时表,来自于非驱动表的排序都是文件排序(usingfilesort 一般当where和order不是同一个字段时会产生文件排序。可以在内存,也可以在硬盘);

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值