知道为什么即使我在 sql 中使用/强制索引作为提示,也没有选择 cli.clitype 和 c.cli。它在 4 秒内给了我输出,只为下面的查询获取 1634。我正在使用 5.5.25.log 请建议。
mysql> explain SELECT   DATE(sr.`date`),   v.company_name,   c.cli,   COUNT(*),   c.charge,   SUM(c.`charge`) FROM subscriptionrequest AS sr, cli AS c ,   vendor AS v WHERE sr.cli = c.cli     AND sr.secretkey = v.secretkey     AND sr.`date` BETWEEN'2012-03-12 00:00:00' AND '2012-10-13 00:00:00' and c.clitype = 'chargemo' GROUP BY DATE(sr.`date`), sr.secretkey,c.cli;
+----+-------------+-------+------+-----------------------------------------------+----------------+---------+----------------------------+------+----------------------------------------------+
| id | select_type | table | type | possible_keys                                 | key            | key_len | ref                        | rows | Extra                                        |
+----+-------------+-------+------+-----------------------------------------------+----------------+---------+----------------------------+------+----------------------------------------------+
|  1 | SIMPLE      | c     | ALL  | idx_cli                                       | NULL           | NULL    | NULL                       |  115 | Using where; Using temporary; Using filesort |
|  1 | SIMPLE      | sr    | ref  | idx_subreq_key,idx_subreq_cli,idx_subreq_date | idx_subreq_cli | 53      | crystal_du_sm.c.cli        |  869 | Using where                                  |
|  1 | SIMPLE      | v     | ref  | secretkey_idx                                 | secretkey_idx  | 52      | crystal_du_sm.sr.secretkey |    1 | Using where                                  |
+----+-------------+-------+------+-----------------------------------------------+----------------+---------+----------------------------+------+----------------------------------------------+
3 rows in set (0.00 sec)
mysql> show indexes from cli;
+-------+------------+--------------+--------------+-------------+-----------+---------     ----+----------+--------+------+------------+---------+---------------+
| Table | Non_unique | Key_name     | Seq_in_index | Column_name | Collation |      Cardinality | Sub_part | Packed | Null | Index_type | Comment | Index_comment |
 +-------+------------+--------------+--------------+-------------+-----------+--------    -----+----------+--------+------+------------+---------+---------------+
| cli   |          0 | PRIMARY      |            1 | idcli       | A         |             115 |     NULL | NULL   |      | BTREE      |         |               |
| cli   |          1 | idx_cli      |            1 | cli         | A         |         115 |     NULL | NULL   |      | BTREE      |         |               |
| cli   |          1 | cli_type_idx |            1 | clitype     | A         |         115 |     NULL | NULL   | YES  | BTREE      |         |               |
+-------+------------+--------------+--------------+-------------+-----------+---------     ----+----------+--------+------+------------+---------+---------------+
3 rows in set (0.00 sec)    
mysql> show create table cli;
| cli   | CREATE TABLE `cli` (
`idcli` bigint(255) NOT NULL AUTO_INCREMENT,
`cli` varchar(256) NOT NULL,
`type` enum('SDMF','MDMF') NOT NULL DEFAULT 'SDMF',
`priority` enum('realtime','high','normal','low','ignore') NOT NULL DEFAULT 'normal',
`status` enum('active','inactive','suspended','deleted') NOT NULL DEFAULT 'active',
`date` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
`description` text,
`charge` float DEFAULT '0',
`clitype` enum('chargemo','freemo') DEFAULT 'freemo',
PRIMARY KEY (`idcli`),
KEY `idx_cli` (`cli`),
KEY `cli_type_idx` (`clitype`)
) ENGINE=InnoDB AUTO_INCREMENT=117 DEFAULT CHARSET=latin1 |
1 row in set (0.00 sec)
mysql> show create table vendor;
| vendor | CREATE TABLE `vendor` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(256) NOT NULL,
`company_name` varchar(256) DEFAULT NULL,
`phone_no` varchar(256) DEFAULT NULL,
`status` enum('active','inactive','suspended','deleted') DEFAULT 'active',
`mo` bigint(255) NOT NULL,
`mt` bigint(255) NOT NULL,
`used_mo` bigint(255) DEFAULT '0',
`used_mt` bigint(255) DEFAULT '0',
`start_time` timestamp NULL DEFAULT '0000-00-00 00:00:00',
`end_time` timestamp NULL DEFAULT '0000-00-00 00:00:00',
`secretkey` varchar(50) NOT NULL,
`callback_url` text,
`payment_callback_url` text,
`date` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
`userid` int(255) DEFAULT NULL,
PRIMARY KEY (`id`),
KEY `secretkey_idx` (`secretkey`)
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=latin1 |
1 row in set (0.00 sec)
| subscriptionrequest | CREATE TABLE `subscriptionrequest` (
`id` bigint(255) unsigned NOT NULL AUTO_INCREMENT,
`ipaddress` varchar(256) CHARACTER SET latin1 NOT NULL DEFAULT '0.0.0.0',
`message` text,
`msisdn` varchar(50) CHARACTER SET latin1 DEFAULT NULL,
`mode` varchar(50) CHARACTER SET latin1 DEFAULT NULL,
`cli` varchar(50) CHARACTER SET latin1 DEFAULT NULL,
`transactionid` varchar(100) DEFAULT NULL,
`secretkey` varchar(100) CHARACTER SET latin1 DEFAULT NULL,
`date` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
`error_code` int(10) DEFAULT NULL,
`success` int(10) NOT NULL DEFAULT '0',
`status` enum('waiting','processing','completed','moexceeds','reject') DEFAULT     'waiting',
PRIMARY KEY (`id`),
KEY `idx_subreq_key` (`secretkey`),
KEY `idx_subreq_status` (`status`),
KEY `idx_subreq_transid` (`transactionid`),
KEY `idx_subreq_cli` (`cli`),
KEY `idx_subreq_date` (`date`)
) ENGINE=InnoDB AUTO_INCREMENT=1594161 DEFAULT CHARSET=utf8 |
对于 SETSUNA ---
mysql> explain SELECT DATE(sr.`date`) AS sr_date, v.company_name, c.cli, 
->   COUNT(*) AS cnt, c.charge, 
->   SUM(c.`charge`) AS charge_sum 
->   FROM 
->   subscriptionrequest AS sr 
->   JOIN cli AS c ON sr.cli = c.cli     
->   JOIN vendor AS v ON sr.secretkey = v.secretkey
->   WHERE 
->   sr.`date` >= '2012-03-12' AND sr.`date` <= '2012-10-13' 
->   AND c.clitype = 'chargemo' 
->   GROUP BY DATE(sr.`date`), sr.secretkey, c.cli;
+----+-------------+-------+------+-----------------------------+----------------+---------     +---------------------------+-------+---------------------------------+
| id | select_type | table | type | possible_keys               | key            | key_len     | ref                       | rows  | Extra                           |
+----+-------------+-------+------+-----------------------------+----------------+---------  +---------------------------+-------+---------------------------------+
|  1 | SIMPLE      | v     | ALL  | secretkey_idx               | NULL           | NULL    | NULL                      |     9 | Using temporary; Using filesort |
|  1 | SIMPLE      | sr    | ref  | idx_subreq_key,cli_date_idx | idx_subreq_key | 103     | crystal_du_sm.v.secretkey | 88746 | Using where                     |
|  1 | SIMPLE      | c     | ref  | idx_cli,cli_type_idx        | idx_cli        | 258         | crystal_du_sm.sr.cli      |     1 | Using where                     |
+----+-------------+-------+------+-----------------------------+----------------+---------   +---------------------------+-------+---------------------------------+
3 rows in set (0.00 sec)
--- 2012 年 8 月 23 日 ---
+----+-------------+-------+------+---------------------------------------+------------  -----+---------+----------------------------+-------+-----------------+
| id | select_type | table | type | possible_keys                         | key               | key_len | ref                        | rows  | Extra           |
+----+-------------+-------+------+---------------------------------------+-----------------+---------+----------------------------+-------+-----------------+
|  1 | SIMPLE      | v     | ALL  | secretkey_idx                         | NULL            | NULL    | NULL                       |     9 | Using temporary |
|  1 | SIMPLE      | sr    | ref  | idx_subreq_key,idx_date_cli_secretkey | idx_subreq_key  | 103     | crystal_du_sm.v.secretkey  | 88608 | Using where     |
|  1 | SIMPLE      | c     | ref  | idx_cli_clitype                       | idx_cli_clitype     | 260     | crystal_du_sm.sr.cli,const |     1 | Using where     |
+----+-------------+-------+------+---------------------------------------+----------------   -+---------+----------------------------+-------+-----------------+
3 rows in set (0.00 sec)