zoukankan      html  css  js  c++  java
  • in 改写优化案例

    l凌晨1点开发迁移业务告知sql响应有问题,赶紧爬起来看看

    6000w的大表,没走索引导致查询了50s,执行计划如下

     desc select a, b, c, d from table where FIND_IN_SET(a,'MD5value1,MD5value2');
    +----+-------------+------------+------+---------------+------+---------+------+----------+-------------+
    | id | select_type | table      | type | possible_keys | key  | key_len | ref  | rows     | Extra       |
    +----+-------------+------------+------+---------------+------+---------+------+----------+-------------+
    |  1 | SIMPLE      | table | ALL  | NULL          | NULL | NULL    | NULL | 60435142 | Using where |
    +----+-------------+------------+------+---------------+------+---------+------+----------+-------------+
    1 row in set (0.01 sec)
    

    使用了in导致查询没有走索引改写为union all sql秒出结果

    select a, b, c, d from table where a='md5value1'
    union all
    select a, b, c, d from table where a='MD5value2';    

    看下执行计划

    +----+--------------+------------+-------+---------------+---------+---------+-------+------+-----------------+
    | id | select_type  | table      | type  | possible_keys | key     | key_len | ref   | rows | Extra           |
    +----+--------------+------------+-------+---------------+---------+---------+-------+------+-----------------+
    |  1 | PRIMARY      | table | const | PRIMARY       | PRIMARY | 302     | const |    1 | NULL            |
    |  2 | UNION        | table | const | PRIMARY       | PRIMARY | 302     | const |    1 | NULL            |
    | NULL | UNION RESULT | <union1,2> | ALL   | NULL          | NULL    | NULL    | NULL  | NULL | Using temporary |
    +----+--------------+------------+-------+---------------+---------+---------+-------+------+-----------------+
    3 rows in set (0.03 sec)
    

     

  • 相关阅读:
    PostgreSQL 语法
    Linux 上安装 PostgreSQL
    Gitlab基础知识介绍
    Grafana 入门知识介绍
    数据卷容器
    Docker网络详解——原理篇
    Docker网络详细理解-容器网络互通
    搭建Elasitc stack集群需要注意的日志问题
    创建Elasticsearch集群并为它们配置TLS安全通信
    Elastic:为Elastic Docker部署设置安全
  • 原文地址:https://www.cnblogs.com/weiwenbo/p/9257414.html
Copyright © 2011-2022 走看看