• sql优化


    目录

    一、EXPLAIN 解释

    1.Type

    ALL

     index

    range

     ref

    2.一些实例


    一、EXPLAIN 解释

    1.Type

    EXPLAIN执行计划中type字段分为以下几种:

    ALL        

    INDEX        

    RANGE        

    REF        

    EQ_REF        

    CONST,SYSTEM        

    NULL

    自上而下,性能从最差到最好

    表结构如下:

    1. CREATE TABLE `film` (
    2. `id` int(4) NOT NULL AUTO_INCREMENT,
    3. `title` varchar(255) DEFAULT NULL,
    4. `name` varchar(255) DEFAULT NULL,
    5. `remark` varchar(255) DEFAULT NULL,
    6. `rating` int(4) DEFAULT NULL,
    7. PRIMARY KEY (`id`),
    8. KEY `idx_title` (`title`) USING BTREE
    9. ) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=utf8;

    1. CREATE TABLE `payment` (
    2. `id` int(4) NOT NULL AUTO_INCREMENT,
    3. `customer_id` int(4) DEFAULT NULL,
    4. `remark` varchar(255) DEFAULT NULL,
    5. PRIMARY KEY (`id`),
    6. KEY `idx_fk_customer_id` (`customer_id`)
    7. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;

    ALL

    type = ALL,全表扫描,MYSQL扫描全表来找到匹配的行

    (因为film表中rating不是索引)

    explain  select * from film where rating > 9;

     index

    type = index,索引全扫描,MYSQL遍历整个索引来查找匹配的行。(虽然where条件中没有用到索引,但是要取出的列title是索引包含的列,所以只要全表扫描索引即可,直接使用索引树查找数据)

    explain select title from film;

    range

    type = range ,索引范围扫描,常见于<、<=、>、>=、between等操作符(因为customer_id是索引,所以只要查找索引的某个范围即可,通过索引找到具体的数据)

    explain select * from payment where customer_id > 300 and customer_id < 350;

     

     ref

    type = ref ,使用非唯一性索引或者唯一索引的前缀扫描,返回匹配某个单独值的记录行。

    (1)使用非唯一性索引customer_id单表查询

    explain select * from payment where customer_id = 350;

    2.一些实例

    表结构如下:

    1. CREATE TABLE `term_mac_iptv_info` (
    2. `BUSI_ID` varchar(50) NOT NULL COMMENT '业务编号',
    3. `MKT_RES_NBR` varchar(50) DEFAULT NULL COMMENT '营销资源编码',
    4. `TERM_CODE` varchar(50) DEFAULT NULL COMMENT '串码',
    5. `MAC_ID` varchar(50) DEFAULT NULL COMMENT 'MAC地址',
    6. `ACTION` int(1) DEFAULT NULL COMMENT '动作 1 新增 2-删除',
    7. `USER_ID` bigint(16) DEFAULT NULL COMMENT '用户ID',
    8. `CREATE_DATE` datetime DEFAULT NULL COMMENT '创建时间',
    9. `DEAL_COUNT` int(1) DEFAULT NULL COMMENT '处理次数',
    10. `RETURN_CODE` varchar(30) DEFAULT NULL COMMENT '返回码',
    11. `RETURN_MSG` varchar(2000) DEFAULT NULL COMMENT '返回描述',
    12. `SEND_PLATFORM` int(1) DEFAULT NULL COMMENT '对端平台 1.华为 2.中兴',
    13. `STATUS_CD` int(1) DEFAULT NULL COMMENT '处理状态 0-未处理 1-处理成功 2-处理失败 3-处理中',
    14. `UPDATE_DATE` datetime DEFAULT NULL COMMENT '更新时间',
    15. PRIMARY KEY (`BUSI_ID`),
    16. KEY `INDX_TERM_MAC_IPTV_INFO_TERM_CODE` (`TERM_CODE`),
    17. KEY `INDX_TERM_MAC_IPTV_INFO_MAC_ID` (`MAC_ID`)
    18. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='IPTV同步中兴华为';

    1. -- 没有where 取出的title不是索引字段,走全表扫描
    2. explain select action from term_mac_iptv_info; 
    3.  -- 没有where 但是要取出的title mac_id是索引列,所以还是会走索引
    4. explain select mac_id from term_mac_iptv_info;
    5. -- 没有where 要取出的title包含非索引列,所以不会走索引,此时全表扫描
    6. explain select mac_id,action from term_mac_iptv_info; 

  • 相关阅读:
    文献阅读2
    SpringBoot中个常见的几个问题
    PyCharm集成开发环境安装、启动与设置
    pod详解
    【Java毕设项目】基于SpringBoot+Vue科研管理系统的设计与实现
    C++字符串类 - std::string - 常用总结
    FFA interface
    CRC校验原理及步骤
    生命科学公司如何使用 OKR
    基本的SELECT语句——“MySQL数据库”
  • 原文地址:https://blog.csdn.net/weixin_38972910/article/details/126153615