加入收藏 | 设为首页 | 会员中心 | 我要投稿 网站开发网_马鞍山站长网 (https://www.0555zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长百科 > 正文

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

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

外部查询条件不能够下推到复杂的视图或子查询的情况有:

  •  聚合子查询;
  •  含有 LIMIT 的子查询;
  •  UNION 或 UNION ALL 子查询;
  •  输出字段中的子查询;

如下面的语句,从执行计划可以看出其条件作用于聚合子查询之后:

  1. SELECT *   
  2. FROM   (SELECT target,   
  3.                Count(*)   
  4.         FROM   operation   
  5.         GROUP  BY target) t   
  6. WHERE  target = 'rm-xxxx'   
  1. +----+-------------+------------+-------+---------------+-------------+---------+-------+------+-------------+  
  2. | id | select_type | table      | type  | possible_keys | key         | key_len | ref   | rows | Extra       |  
  3. +----+-------------+------------+-------+---------------+-------------+---------+-------+------+-------------+  
  4. |  1 | PRIMARY     | <derived2> | ref   | <auto_key0>   | <auto_key0> | 514     | const |    2 | Using where |  
  5. |  2 | DERIVED     | operation  | index | idx_4         | idx_4       | 519     | NULL  |   20 | Using index |  
  6. +----+-------------+------------+-------+---------------+-------------+---------+-------+------+-------------+ 

(编辑:网站开发网_马鞍山站长网)

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