- 添加索引,但是数据倾斜比较大的时候不适合加索引。
比如is_delete字段,大部分是0,如果添加索引,回表次数很多,导致性能变差 - 产生临时表要消除临时表。
- 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不是同一个字段时会产生文件排序。可以在内存,也可以在硬盘);