zoukankan      html  css  js  c++  java
  • MySQL巧建sum索引帮我们提高至少100%的效率

    有两个表,表a

    CREATE TABLE `a` (
    `id` mediumint(
    8) unsigned NOT NULL AUTO_INCREMENT,
    `fid`
    smallint(6) unsigned NOT NULL DEFAULT '0',
    `cnt`
    smallint(6) unsigned NOT NULL DEFAULT '0',
    ...
    ...
    ...
    PRIMARY KEY (`id`),
    KEY `idx_fid` (`fid`),
    ) ENGINE
    =MyISAM DEFAULT CHARSET=utf8

     表b

    CREATE TABLE `b`
    (`fid`
    smallint(6) unsigned NOT NULL AUTO_INCREMENT,
    `name`
    char(50) NOT NULL DEFAULT '',
    ...
    ...
    ...
    PRIMARY KEY (`fid`),
    ) ENGINE
    =MyISAM DEFAULT CHARSET=utf8

     操作SQL如下:

    SELECT COUNT(*) AS num1, SUM(a.cnt)+COUNT(*) AS num2
    FROM a, b
    WHERE b.fid='10913' AND a.fid=b.fid

    我们先看下执行计划:

    我们可以看到扫描行数是229049行,执行时间:

    太可怕了,运行set profiling=1,让我们看看时间主要消耗在哪里?

    sending data花费的时间较长,那这段时间到底是做什么的呢?先看下这个吧:http://renxijun.blog.sohu.com/82906360.html

    意思是它在为select语句准备数据,解决办法:

    建索引:

    create index idx_fid_cnt on a (fid,cnt);

    再看下,执行计划和执行时间:

    总结:使用恰当的索引,是sql的效率倍增,类似sum的函数还有min(),max(),这些都需要在字段上建索引

  • 相关阅读:
    快速排序
    优先队列
    堆排序
    树、二叉树基础
    分治法
    递归算法详细分析
    算法基础
    Linux文件系统详解
    fs/ext2/inode.c相关函数注释
    块设备的读流程分析
  • 原文地址:https://www.cnblogs.com/sunss/p/1864949.html
Copyright © 2011-2022 走看看