【问题标题】:MySQL - Querying Large table in MySQL -MySQL - 在 MySQL 中查询大表 -
【发布时间】:2014-07-01 08:32:02
【问题描述】:

这似乎是college_major 表的糟糕设计。

CREATE TABLE `college_majors` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `date_time` datetime DEFAULT NULL,
  `UNITID` varchar(255) DEFAULT NULL,
  `CIPCODE` varchar(255) DEFAULT NULL,
  `AWLEVEL` varchar(255) DEFAULT NULL,
  `CTOTALT` varchar(255) DEFAULT NULL,
  `CTOTALM` varchar(255) DEFAULT NULL,
  `CTOTALW` varchar(255) DEFAULT NULL,
  `CAIANT` varchar(255) DEFAULT NULL,
  `CASIAT` varchar(255) DEFAULT NULL,
  `CBKAAT` varchar(255) DEFAULT NULL,
  `CHISPT` varchar(255) DEFAULT NULL,
  `CNHPIT` varchar(255) DEFAULT NULL,
  `CWHITT` varchar(255) DEFAULT NULL,
  `C2MORT` varchar(255) DEFAULT NULL,
  `CUNKNT` varchar(255) DEFAULT NULL,
  `CNRALT` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=270167 DEFAULT CHARSET=utf8;

我可以将此表缩减为三列 - id、CIPCODE 和 UNITID。但问题是,即使是像 *select * FROM college_majors* 这样的简单查询也需要很长时间才能执行,有时甚至无法执行。

我将查询执行时间增加到 6000.00 秒,但查询仍然无法运行。

关于如何改进设计、创建新表并插入该表中的数据(college_majors)的任何建议。

谢谢, 一个

【问题讨论】:

  • 一方面,将LEFT JOINWHERE 子句一起使用是没有意义的。
  • 是否有理由进行左加入 College_majors_mapping?这会减慢查询速度。
  • 似乎college_majors 的表格设计不正确。我可以将其简化为带有 id、CIPCODE 和 UNITID 的三列表。然后将数据插入到新表中。但即使我在college_majors 上运行查询,即使是像select * FROM a4c_college_majors 这样的简单查询;大约 600-800 秒需要太多时间。有什么建议吗?
  • 您的表上似乎没有任何有用的连接索引。除了可以接受的非常基本的查询之外,这些对于任何事情都非常重要。
  • 是的。第一步必须是阅读规范化。第 2 步将是索引的正确应用。

标签: mysql performance join


【解决方案1】:

如果 College_majors_mapping 中的字段“codevalue”是唯一的,您可以对其进行索引并提高连接性能。

【讨论】:

猜你喜欢
  • 2012-01-13
  • 2012-07-17
  • 1970-01-01
  • 2016-09-30
  • 2016-04-14
  • 1970-01-01
  • 1970-01-01
  • 2017-03-15
  • 1970-01-01
相关资源
最近更新 更多