4

我正在尝试连接 MySQL 数据库中的两个表,但它似乎没有使用第二个表上的主键。不知道是不是查询错了,还是主键不能用,如何进一步优化。目前,查询需要 20 秒才能运行。

我正在运行的查询是:

SELECT * FROM journeyPatternTimingLink2 INNER JOIN stops ON stops.atcoCode = journeyPatternTimingLink2.from WHERE journeyPatternId = '113958'

我的表结构如下:

CREATE TABLE IF NOT EXISTS `journeyPatternTimingLink2` (
  `journeyPatternTimingLinkId` int(11) NOT NULL AUTO_INCREMENT,
  `journeyPatternId` int(11) NOT NULL,
  `from` varchar(15) NOT NULL,
  `to` varchar(15) NOT NULL,
  `direction` enum('inbound','outbound') NOT NULL,
  `runTime` varchar(15) NOT NULL,
  PRIMARY KEY (`journeyPatternTimingLinkId`),
  KEY `journeyPatternId` (`journeyPatternId`),
  KEY `from` (`from`)
) ENGINE=InnoDB  DEFAULT CHARSET=utf8 AUTO_INCREMENT=13652793 ;

--
-- Table structure for table `stops`
--

CREATE TABLE IF NOT EXISTS `stops` (
  `atcoCode` varchar(25) NOT NULL,
  `longitude` varchar(30) NOT NULL,
  `latitude` varchar(30) NOT NULL,
  PRIMARY KEY (`atcoCode`),
  KEY `location` (`longitude`,`latitude`),
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

最后,这是我在查询中运行解释的屏幕截图。我不应该看到停止表上使用了某种索引吗?

谢谢。

4

2 回答 2

5

您的两个字段使用不同的字符集。

让两个表都使用UTF8.

于 2012-11-06T21:07:31.897 回答
0

您还可以在各个表的 FROM 和 TO 列上使用“索引”来加速表查找。

在 JourneyPatternTimingLink2(from) 上创建索引 indexFrom;

CREATE INDEX indexAtcoCode on stop(atcoCode);

于 2012-11-07T03:11:13.273 回答