加入收藏 | 设为首页 | 会员中心 | 我要投稿 鄂州站长网 (https://www.0711zz.com.cn/)- 云通信、区块链、物联平台、操作系统、高性能计算!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

8种常见SQL错误用法

发布时间:2019-06-02 11:05:53 所属栏目:MySql教程 来源:db匠
导读:1、LIMIT 语句 分页查询是最常用的场景之一,但也通常也是最容易出问题的地方。比如对于下面简单的语句,一般 DBA 想到的办法是在 type, name, create_time 字段上加组合索引。这样条件排序都能有效的利用到索引,性能迅速提升。 SELECT* FROMoperation WH

再来看下面这个已经初步优化过的例子(左连接中的主表优先作用查询条件):

  1. SELECT    a.*,   
  2.           c.allocated   
  3. FROM      (   
  4.               SELECT   resourceid   
  5.               FROM     my_distribute d   
  6.                    WHERE    isdelete = 0   
  7.                    AND      cusmanagercode = '1234567'   
  8.                    ORDER BY salecode limit 20) a   
  9. LEFT JOIN   
  10.           (   
  11.               SELECT   resourcesid, sum(ifnull(allocation, 0) * 12345) allocated   
  12.               FROM     my_resources   
  13.                    GROUP BY resourcesid) c   
  14. ON        a.resourceid = c.resourcesid 

那么该语句还存在其它问题吗?不难看出子查询 c 是全表聚合查询,在表数量特别大的情况下会导致整个语句的性能下降。

(编辑:鄂州站长网)

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

热点阅读