设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 创业者 数据 手机
当前位置: 首页 > 站长学院 > MySql教程 > 正文

8种你可能正在写错的SQL用法(7)

发布时间:2019-07-22 15:59 所属栏目:115 来源:佚名
导读:由于最后 WHERE 条件以及排序均针对最左主表,因此可以先对 my_order 排序提前缩小数据量再做左连接。SQL 重写后如下,执行时间缩小为1毫秒左右。 SELECT* FROM( SELECT* FROMmy_ordero WHERE(o.display=0) AND(o.o

由于最后 WHERE 条件以及排序均针对最左主表,因此可以先对 my_order 排序提前缩小数据量再做左连接。SQL 重写后如下,执行时间缩小为1毫秒左右。

  1. SELECT *   
  2. FROM (  
  3. SELECT *   
  4. FROM   my_order o   
  5. WHERE  ( o.display = 0 )   
  6.        AND ( o.ostaus = 1 )   
  7. ORDER  BY o.selltime DESC   
  8. LIMIT  0, 15  
  9. ) o   
  10.      LEFT JOIN my_userinfo u   
  11.               ON o.uid = u.uid   
  12.      LEFT JOIN my_productinfo p   
  13.               ON o.pid = p.pid   
  14. ORDER BY  o.selltime DESC  
  15. limit 0, 15 

再检查执行计划:子查询物化后(select_type=DERIVED)参与 JOIN。虽然估算行扫描仍然为90万,但是利用了索引以及 LIMIT 子句后,实际执行时间变得很小。

  1. +----+-------------+------------+--------+---------------+---------+---------+-------+--------+----------------------------------------------------+  
  2. | id | select_type | table      | type   | possible_keys | key     | key_len | ref   | rows   | Extra                                              |  
  3. +----+-------------+------------+--------+---------------+---------+---------+-------+--------+----------------------------------------------------+  
  4. |  1 | PRIMARY     | <derived2> | ALL    | NULL          | NULL    | NULL    | NULL  |     15 | Using temporary; Using filesort                    |  
  5. |  1 | PRIMARY     | u          | eq_ref | PRIMARY       | PRIMARY | 4       | o.uid |      1 | NULL                                               |  
  6. |  1 | PRIMARY     | p          | ALL    | PRIMARY       | NULL    | NULL    | NULL  |      6 | Using where; Using join buffer (Block Nested Loop) |  
  7. |  2 | DERIVED     | o          | index  | NULL          | idx_1   | 5       | NULL  | 909112 | Using where                                        |  
  8. +----+-------------+------------+--------+---------------+---------+---------+-------+--------+----------------------------------------------------+ 

8、中间结果集下推

(编辑:ASP站长网)

网友评论
推荐文章
    热点阅读