MySQL添加索引优化SQL

在慢查询日志中有一条慢SQL,执行时间约为3秒

mysql> SELECT
    -> t.total_meeting_num,
    -> r.voip_user_num
    -> FROM
    -> (
    -> SELECT
    -> count(*) total_meeting_num
    -> FROM
    -> Conference
    -> WHERE
    -> isStart = 1
    -> AND startTime >= ADDDATE(now(), - 1)
    -> AND billingcode != 651158
    -> AND billingcode != 651204
    -> ) t,
    -> (
    -> SELECT
    -> count(userID) voip_user_num
    -> FROM
    -> (
    -> SELECT
    -> conferenceID,
    -> userID,
    -> isOnline,
    -> createdTime
    -> FROM
    -> (
    -> SELECT
    -> *
    -> FROM
    -> ConferenceUser
    -> WHERE
    -> createdTime >= ADDDATE(now(), - 1)
    -> AND userID > 1000
    -> ORDER BY
    -> userID,
    -> createdTime DESC
    -> ) t
    -> GROUP BY
    -> userID
    -> ) t,
    -> (
    -> SELECT
    -> *
    -> FROM
    -> Conference
    -> WHERE
    -> isStart = 1
    -> AND startTime >= ADDDATE(now(), - 1)
    -> AND conferenceName NOT LIKE 'evmonitor%'
    -> ) r
    -> WHERE
    -> t.isOnline = 1
    -> AND t.conferenceID = r.conferenceID
    -> ) r;
+-------------------+---------------+
| total_meeting_num | voip_user_num |
+-------------------+---------------+
|                29 |            48 |
+-------------------+---------------+
1 row in set (3.01 sec)

查看执行计划

mysql> explain SELECT
    -> t.total_meeting_num,
    -> r.voip_user_num
    -> FROM
    -> (
    -> SELECT
    -> count(*) total_meeting_num
    -> FROM
    -> Conference
    -> WHERE
    -> isStart = 1
    -> AND startTime >= ADDDATE(now(), - 1)
    -> AND billingcode != 651158
    -> AND billingcode != 651204
    -> ) t,
    -> (
    -> SELECT
    -> count(userID) voip_user_num
    -> FROM
    -> (
    -> SELECT
    -> conferenceID,
    -> userID,
    -> isOnline,
    -> createdTime
    -> FROM
    -> (
    -> SELECT
    -> *
    -> FROM
    -> ConferenceUser
    -> WHERE
    -> createdTime >= ADDDATE(now(), - 1)
    -> AND userID > 1000
    -> ORDER BY
    -> userID,
    -> createdTime DESC
    -> ) t
    -> GROUP BY
    -> userID
    -> ) t,
    -> (
    -> SELECT
    -> *
    -> FROM
    -> Conference
    -> WHERE
    -> isStart = 1
    -> AND startTime >= ADDDATE(now(), - 1)
    -> AND conferenceName NOT LIKE 'evmonitor%'
    -> ) r
    -> WHERE
    -> t.isOnline = 1
    -> AND t.conferenceID = r.conferenceID
    -> ) r;
+----+-------------+----------------+--------+----------------+----------------+---------+------+---------+---------------------------------+
| id | select_type | table          | type   | possible_keys  | key            | key_len | ref  | rows    | Extra                           |
+----+-------------+----------------+--------+----------------+----------------+---------+------+---------+---------------------------------+
|  1 | PRIMARY     | <derived2>     | system | NULL           | NULL           | NULL    | NULL |       1 |                                 |
|  1 | PRIMARY     | <derived3>     | system | NULL           | NULL           | NULL    | NULL |       1 |                                 |
|  3 | DERIVED     | <derived6>     | ALL    | NULL           | NULL           | NULL    | NULL |      18 |                                 |
|  3 | DERIVED     | <derived4>     | ALL    | NULL           | NULL           | NULL    | NULL |   12667 | Using where; Using join buffer  |
|  6 | DERIVED     | Conference     | range  | ind_start_time | ind_start_time | 5       | NULL |     889 | Using where                     |
|  4 | DERIVED     | <derived5>     | ALL    | NULL           | NULL           | NULL    | NULL |   18918 | Using temporary; Using filesort |
|  5 | DERIVED     | ConferenceUser | ALL    | NULL           | NULL           | NULL    | NULL | 6439656 | Using where; Using filesort     |
|  2 | DERIVED     | Conference     | range  | ind_start_time | ind_start_time | 5       | NULL |     889 | Using where                     |
+----+-------------+----------------+--------+----------------+----------------+---------+------+---------+---------------------------------+
8 rows in set (3.04 sec)

查看索引

mysql> show index from ConferenceUser;
+----------------+------------+-----------------------+--------------+--------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
| Table          | Non_unique | Key_name              | Seq_in_index | Column_name  | Collation | Cardinality | Sub_part | Packed | Null | Index_type | Comment | Index_comment |
+----------------+------------+-----------------------+--------------+--------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
| ConferenceUser |          0 | PRIMARY               |            1 | recordID     | A         |     6439758 |     NULL | NULL   |      | BTREE      |         |               |
| ConferenceUser |          0 | PRIMARY               |            2 | conferenceID | A         |     6439758 |     NULL | NULL   |      | BTREE      |         |               |
| ConferenceUser |          1 | ind_conference_userID |            1 | conferenceID | A         |      804969 |     NULL | NULL   |      | BTREE      |         |               |
| ConferenceUser |          1 | ind_conference_userID |            2 | userID       | A         |     3219879 |     NULL | NULL   |      | BTREE      |         |               |
+----------------+------------+-----------------------+--------------+--------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
4 rows in set (0.00 sec)

在表的列上添加索引

mysql> alter table ConferenceUser add index index_createdtime(createdTime);
    
Query OK, 6439784 rows affected (38.46 sec)
Records: 6439784  Duplicates: 0  Warnings: 0
查看索引
mysql> show index from ConferenceUser;
+----------------+------------+-----------------------+--------------+--------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
| Table          | Non_unique | Key_name              | Seq_in_index | Column_name  | Collation | Cardinality | Sub_part | Packed | Null | Index_type | Comment | Index_comment |
+----------------+------------+-----------------------+--------------+--------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
| ConferenceUser |          0 | PRIMARY               |            1 | recordID     | A         |        NULL |     NULL | NULL   |      | BTREE      |         |               |
| ConferenceUser |          0 | PRIMARY               |            2 | conferenceID | A         |     6439794 |     NULL | NULL   |      | BTREE      |         |               |
| ConferenceUser |          1 | ind_conference_userID |            1 | conferenceID | A         |      715532 |     NULL | NULL   |      | BTREE      |         |               |
| ConferenceUser |          1 | ind_conference_userID |            2 | userID       | A         |     3219897 |     NULL | NULL   |      | BTREE      |         |               |
| ConferenceUser |          1 | index_createdtime     |            1 | createdTime  | A         |     6439794 |     NULL | NULL   |      | BTREE      |         |               |
+----------------+------------+-----------------------+--------------+--------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
5 rows in set (0.00 sec)

再次执行时间缩短为0.17秒

mysql> SELECT
    -> t.total_meeting_num,
    -> r.voip_user_num
    -> FROM
    -> (
    -> SELECT
    -> count(*) total_meeting_num
    -> FROM
    -> Conference
    -> WHERE
    -> isStart = 1
    -> AND startTime >= ADDDATE(now(), - 1)
    -> AND billingcode != 651158
    -> AND billingcode != 651204
    -> ) t,
    -> (
    -> SELECT
    -> count(userID) voip_user_num
    -> FROM
    -> (
    -> SELECT
    -> conferenceID,
    -> userID,
    -> isOnline,
    -> createdTime
    -> FROM
    -> (
    -> SELECT
    -> *
    -> FROM
    -> ConferenceUser
    -> WHERE
    -> createdTime >= ADDDATE(now(), - 1)
    -> AND userID > 1000
    -> ORDER BY
    -> userID,
    -> createdTime DESC
    -> ) t
    -> GROUP BY
    -> userID
    -> ) t,
    -> (
    -> SELECT
    -> *
    -> FROM
    -> Conference
    -> WHERE
    -> isStart = 1
    -> AND startTime >= ADDDATE(now(), - 1)
    -> AND conferenceName NOT LIKE 'evmonitor%'
    -> ) r
    -> WHERE
    -> t.isOnline = 1
    -> AND t.conferenceID = r.conferenceID
    -> ) r;
+-------------------+---------------+
| total_meeting_num | voip_user_num |
+-------------------+---------------+
|                29 |            52 |
+-------------------+---------------+
1 row in set (0.17 sec)

查看执行计划

mysql> explain SELECT
    -> t.total_meeting_num,
    -> r.voip_user_num
    -> FROM
    -> (
    -> SELECT
    -> count(*) total_meeting_num
    -> FROM
    -> Conference
    -> WHERE
    -> isStart = 1
    -> AND startTime >= ADDDATE(now(), - 1)
    -> AND billingcode != 651158
    -> AND billingcode != 651204
    -> ) t,
    -> (
    -> SELECT
    -> count(userID) voip_user_num
    -> FROM
    -> (
    -> SELECT
    -> conferenceID,
    -> userID,
    -> isOnline,
    -> createdTime
    -> FROM
    -> (
    -> SELECT
    -> *
    -> FROM
    -> ConferenceUser
    -> WHERE
    -> createdTime >= ADDDATE(now(), - 1)
    -> AND userID > 1000
    -> ORDER BY
    -> userID,
    -> createdTime DESC
    -> ) t
    -> GROUP BY
    -> userID
    -> ) t,
    -> (
    -> SELECT
    -> *
    -> FROM
    -> Conference
    -> WHERE
    -> isStart = 1
    -> AND startTime >= ADDDATE(now(), - 1)
    -> AND conferenceName NOT LIKE 'evmonitor%'
    -> ) r
    -> WHERE
    -> t.isOnline = 1
    -> AND t.conferenceID = r.conferenceID
    -> ) r;
+----+-------------+----------------+--------+-------------------+-------------------+---------+------+-------+---------------------------------+
| id | select_type | table          | type   | possible_keys     | key               | key_len | ref  | rows  | Extra                           |
+----+-------------+----------------+--------+-------------------+-------------------+---------+------+-------+---------------------------------+
|  1 | PRIMARY     | <derived2>     | system | NULL              | NULL              | NULL    | NULL |     1 |                                 |
|  1 | PRIMARY     | <derived3>     | system | NULL              | NULL              | NULL    | NULL |     1 |                                 |
|  3 | DERIVED     | <derived6>     | ALL    | NULL              | NULL              | NULL    | NULL |    20 |                                 |
|  3 | DERIVED     | <derived4>     | ALL    | NULL              | NULL              | NULL    | NULL | 12682 | Using where; Using join buffer  |
|  6 | DERIVED     | Conference     | range  | ind_start_time    | ind_start_time    | 5       | NULL |   879 | Using where                     |
|  4 | DERIVED     | <derived5>     | ALL    | NULL              | NULL              | NULL    | NULL | 18951 | Using temporary; Using filesort |
|  5 | DERIVED     | ConferenceUser | range  | index_createdtime | index_createdtime | 4       | NULL | 31455 | Using where; Using filesort     |
|  2 | DERIVED     | Conference     | range  | ind_start_time    | ind_start_time    | 5       | NULL |   879 | Using where                     |
+----+-------------+----------------+--------+-------------------+-------------------+---------+------+-------+---------------------------------+
8 rows in set (0.18 sec)

原文地址:http://blog.51cto.com/11784929/2091627

时间: 2024-10-01 03:54:27

MySQL添加索引优化SQL的相关文章

mysql hash索引优化

创建表 CREATE TABLE `t1` (  `id` int(11) NOT NULL AUTO_INCREMENT,  `msg` varchar(20) NOT NULL DEFAULT '',  `crcmsg` int(15) NOT NULL DEFAULT '0',  PRIMARY KEY (`id`)) ENGINE=MyISAM AUTO_INCREMENT=3 DEFAULT CHARSET=utf8 //插入数据 insert into t1 (msg) values

mysql添加索引命令

mysql添加索引命令 1.PRIMARY  KEY(主键索引)mysql>ALTER  TABLE  `table_name`  ADD  PRIMARY  KEY (  `column`  ) 2.UNIQUE(唯一索引)        mysql>ALTER  TABLE  `table_name`  ADD  UNIQUE (`column` ) 3.INDEX(普通索引)mysql>ALTER  TABLE  `table_name`  ADD  INDEX index_nam

mysql数据库添加索引优化查询效率

项目中如果表中的数据过多的话,会影响查询的效率,那么我们需要想办法优化查询,通常添加索引就是我们的选择之一: 1.添加PRIMARY KEY(主键索引) mysql>ALTER TABLE `table_name` ADD PRIMARY KEY ( `column` ) 2.添加UNIQUE(唯一索引) mysql>ALTER TABLE `table_name` ADD UNIQUE ( `column` ) 3.添加INDEX(普通索引) mysql>ALTER TABLE `ta

mysql使用索引优化查询效率

索引的概念 索引是一种特殊的文件(InnoDB数据表上的索引是表空间的一个组成部分),它们包含着对数据表里所有记录的引用指针.更通俗的说,数据库索引好比是一本书前面的目录,能加快数据库的查询速度.在没有索引的情况下,数据库会遍历全部数据后选择符合条件的:而有了相应的索引之后,数据库会直接在索引中查找符合条件的选项.如果我们把SQL语句换成"SELECT * FROM 表名 WHERE id=2000000",那么你是希望数据库按照顺序读取完200万行数据以后给你结果还是直接在索引中定位

MySQL的索引优化,查询优化

MySQL逻辑架构 如果能在头脑中构建一幅MySQL各组件之间如何协同工作的架构图,有助于深入理解MySQL服务器.下图展示了MySQL的逻辑架构图. MySQL逻辑架构,来自:高性能MySQL MySQL逻辑架构整体分为三层,最上层为客户端层,并非MySQL所独有,诸如:连接处理.授权认证.安全等功能均在这一层处理. MySQL大多数核心服务均在中间这一层,包括查询解析.分析.优化.缓存.内置函数(比如:时间.数学.加密等函数).所有的跨存储引擎的功能也在这一层实现:存储过程.触发器.视图等.

MySQL 添加索引,删除索引及其用法

一.索引的作用 一般的应用系统,读写比例在10:1左右,而且插入操作和一般的更新操作很少出现性能问题,遇到最多的,也是最容易出问题的,还是一些复杂的查询操作,所以查询语句的优化显然是重中之重. 在数据量和访问量不大的情况下,mysql访问是非常快的,是否加索引对访问影响不大.但是当数据量和访问量剧增的时候,就会发现mysql变慢,甚至down掉,这就必须要考虑优化sql了,给数据库建立正确合理的索引,是mysql优化的一个重要手段. 索引的目的在于提高查询效率,可以类比字典,如果要查“mysql

mysql 添加索引 mysql 如何创建索引

1.添加PRIMARY KEY(主键索引) mysql>ALTER TABLE `table_name` ADD PRIMARY KEY ( `column` ) 2.添加UNIQUE(唯一索引) mysql>ALTER TABLE `table_name` ADD UNIQUE ( `column` ) 3.添加INDEX(普通索引) mysql>ALTER TABLE `table_name` ADD INDEX index_name ( `column` ) 4.添加FULLTEX

mysql 添加索引

1.添加PRIMARY KEY(主键索引) mysql>ALTER TABLE `table_name` ADD PRIMARY KEY ( `column` ) 2.添加UNIQUE(唯一索引) mysql>ALTER TABLE `table_name` ADD UNIQUE ( `column` ) 3.添加INDEX(普通索引) mysql>ALTER TABLE `table_name` ADD INDEX index_name ( `column` ) 4.添加FULLTEX

mysql使用索引优化order排序

个人原创地址:http://www.phpthinking.com/archives/433 在数据库中我们一般都会对一些字段进行索引操作,这样可以提升数据的查询速度,同时提高数据库的性能像order by ,group by前都需要索引. 先我们要注意一下1>mysql一次查询只能使用一个索引.如果要对多个字段使用索引,建立复合索引.2>在ORDER BY操作中,MySQL只有在排序条件不是一个查询条件表达式的情况下才使用索引.关于索引一些说法 MySQL索引通常是被用于提高WHERE条件的