加入收藏 | 设为首页 | 会员中心 | 我要投稿 惠州站长网 (https://www.0752zz.com.cn/)- 办公协同、云通信、物联设备、操作系统、高性能计算!
当前位置: 首页 > 建站 > 正文

你不会还在用这8个错误的SQL写法吧?

发布时间:2019-09-22 10:37:19 所属栏目:建站 来源:Java架构师追风
导读:副标题#e# 1、LIMIT 语句 分页查询是最常用的场景之一,但也通常也是最容易出问题的地方。比如对于下面简单的语句,一般 DBA 想到的办法是在 type, name, create_time 字段上加组合索引。这样条件排序都能有效的利用到索引,性能迅速提升。 SELECT* FROMope

由于 is_reply 只有0和1两种状态,我们按照下面的方法重写后,执行时间从1.58秒降低到2毫秒。

  1. SELECT *  
  2. FROM ((SELECT * 
  3.  FROM my_order o  
  4.  INNER JOIN my_appraise a  
  5.  ON a.orderid = o.id  
  6.  AND is_reply = 0  
  7.  ORDER BY appraise_time DESC  
  8.  LIMIT 0, 20)  
  9.  UNION ALL  
  10.  (SELECT * 
  11.  FROM my_order o  
  12.  INNER JOIN my_appraise a  
  13.  ON a.orderid = o.id  
  14.  AND is_reply = 1  
  15.  ORDER BY appraise_time DESC  
  16.  LIMIT 0, 20)) t  
  17. ORDER BY is_reply ASC,  
  18.  appraisetime DESC  
  19. LIMIT 20; 

5、EXISTS语句

MySQL 对待 EXISTS 子句时,仍然采用嵌套子查询的执行方式。如下面的 SQL 语句:

  1. SELECT * 
  2. FROM my_neighbor n  
  3.  LEFT JOIN my_neighbor_apply sra  
  4.  ON n.id = sra.neighbor_id  
  5.  AND sra.user_id = 'xxx'  
  6. WHERE n.topic_status < 4  
  7.  AND EXISTS(SELECT 1  
  8.  FROM message_info m  
  9.  WHERE n.id = m.neighbor_id  
  10.  AND m.inuser = 'xxx')  
  11.  AND n.topic_type <> 5  

(编辑:惠州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

推荐文章
    热点阅读