加入收藏 | 设为首页 | 会员中心 | 我要投稿 拼字网 - 核心网 (https://www.hexinwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

这些常被忽视的SQL错误用法,你知道吗

发布时间:2019-09-25 14:33:09 所属栏目:MySql教程 来源:佚名
导读:sql语句的执行顺序: FROM left_table ON join_condition join_type JOIN right_table WHERE where_condition GROUPBY group_by_list HAVING having_condition SELECT DISTINCT select_list ORDERBY order_by_condition LIMIT limit_number 1、LIMIT 语句

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  

执行计划为:

  1. +----+--------------------+-------+------+-----+------------------------------------------+---------+-------+---------+ -----+ 
  2. | id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra | 
  3. +----+--------------------+-------+------+ -----+------------------------------------------+---------+-------+---------+ -----+ 
  4. | 1 | PRIMARY | n | ALL | | NULL | NULL | NULL | 1086041 | Using where | 
  5. | 1 | PRIMARY | sra | ref | | idx_user_id | 123 | const | 1 | Using where | 
  6. | 2 | DEPENDENT SUBQUERY | m | ref | | idx_message_info | 122 | const | 1 | Using index condition; Using where | 
  7. +----+--------------------+-------+------+ -----+------------------------------------------+---------+-------+---------+ -----+ 

去掉 exists 更改为 join,能够避免嵌套子查询,将执行时间从1.93秒降低为1毫秒。

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

新的执行计划:

  1. +----+-------------+-------+--------+ -----+------------------------------------------+---------+ -----+------+ -----+ 
  2. | id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra | 
  3. +----+-------------+-------+--------+ -----+------------------------------------------+---------+ -----+------+ -----+ 
  4. | 1 | SIMPLE | m | ref | | idx_message_info | 122 | const | 1 | Using index condition | 
  5. | 1 | SIMPLE | n | eq_ref | | PRIMARY | 122 | ighbor_id | 1 | Using where | 
  6. | 1 | SIMPLE | sra | ref | | idx_user_id | 123 | const | 1 | Using where | 
  7. +----+-------------+-------+--------+ -----+------------------------------------------+---------+ -----+------+ -----+ 

6、条件下推

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

  1. 聚合子查询;
  2. 含有 LIMIT 的子查询;
  3. UNION 或 UNION ALL 子查询;
  4. 输出字段中的子查询;

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

  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. +----+-------------+------------+-------+---------------+-------------+---------+-------+------+-------------+ 

(编辑:拼字网 - 核心网)

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