我的MySQL查询运行速度非常慢,因为它没有在连接键上使用索引。我的表结构有什么问题,优化器没有使用索引?
mysql> EXPLAIN SELECT * FROM indicator_performance_averages
LEFT OUTER JOIN `prof` ON (`prof`.`symbol` = indicator_performance_averages.`symbol`)
WHERE (indicator_performance_averages.`symbol` = 'ZCN13');
+----+-------------+--------------------------------+-------+---------------+------------+---------+-------+---------+-------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+--------------------------------+-------+---------------+------------+---------+-------+---------+-------+
| 1 | SIMPLE | indicator_performance_averages | const | idx_symbol | idx_symbol | 98 | const | 1 | |
| 1 | SIMPLE | prof | ALL | NULL | NULL | NULL | NULL | 1102075 | |
+----+-------------+--------------------------------+-------+---------------+------------+---------+-------+---------+-------+
mysql> DESCRIBE indicator_performance_averages;
+--------------------+------------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+--------------------+------------------+------+-----+---------+----------------+
| id | int(11) unsigned | NO | PRI | NULL | auto_increment |
| symbol | varchar(32) | NO | UNI | NULL | |
| date | date | YES | | NULL | |
| last_update | timestamp | YES | | NULL | |
+--------------------+------------------+------+-----+---------+----------------+
mysql> DESCRIBE prof;
+---------------+---------------------+------+-----+---------------------+----------------+
| Field | Type | Null | Key | Default | Extra |
+---------------+---------------------+------+-----+---------------------+----------------+
| id | bigint(20) unsigned | NO | PRI | NULL | auto_increment |
| symbol | varchar(32) | NO | UNI | NULL | |
| name | varchar(128) | NO | | NULL | |
| lastupdate | datetime | NO | | 0000-00-00 00:00:00 | |
+---------------+---------------------+------+-----+---------------------+----------------+
编辑:为两个表添加SHOW CREATE TABLE:
CREATE TABLE `indicator_performance_averages` (
`id` int(11) unsigned NOT NULL auto_increment,
`symbol` varchar(32) character set utf8 NOT NULL,
`date` date default NULL,
`last_update` timestamp NULL default NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `idx_symbol` (`symbol`)
) ENGINE=InnoDB AUTO_INCREMENT=6719 DEFAULT CHARSET=latin1
CREATE TABLE `prof` (
`id` bigint(20) unsigned NOT NULL auto_increment,
`symbol` varchar(32) NOT NULL,
`name` varchar(128) NOT NULL,
`lastupdate` datetime NOT NULL default '0000-00-00 00:00:00',
PRIMARY KEY (`id`),
UNIQUE KEY `id_UNIQUE` (`id`),
UNIQUE KEY `IDX_symbol` (`symbol`),
) ENGINE=InnoDB AUTO_INCREMENT=37736071 DEFAULT CHARSET=latin1
答案 0 :(得分:0)
问题是{_ 1}}指示符__ performance_averages.symbol与prof.symbol上的character set utf8
不匹配。
这可以防止MySQL在prof.symbol上使用索引。
要使索引可用于查询计划,您需要转换谓词中的字符集以匹配列的数据类型。尝试将连接谓词更改为此...
character set latin1
(我认为这是正确的语法。我们要做的是让MySQL从ipa表中获取utf8值,并在查找prof表之前将其转换为latin1。 ()函数也可以使用。)