繁体   English   中英

如何加快MySQL查询速度

[英]How to speed up MySQL query

我正在尝试在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;

最后这是一个截图,我在查询上运行解释 我不应该看到在停靠表上使用某种索引吗?

谢谢。

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

使两个表都使用UTF8

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

在journeyPatternTimingLink2(from)上创建INDEX indexFrom;

停止时创建INDEX indexAtcoCode(atcoCode);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM