MySQL注释掉Alter表分区语句

时间:2018-10-09 18:53:49

标签: mysql partitioning

我有一个表,目前是空的,但将装载数亿条记录。在执行此加载之前,我想在表上创建一些分区以提高查询性能并在以后实现更好的删除(只需截断整个分区)。

我正在使用的alter table代码是:

ALTER TABLE `TABLE_NAME` 
 PARTITION BY RANGE (YEAR(DATE_FIELD)) (
 PARTITION y1 VALUES LESS THAN (2017),
 PARTITION y2 VALUES LESS THAN (2018),
 PARTITION y3 VALUES LESS THAN (2019),
 PARTITION ymax VALUES LESS THAN (2050)
 );

当我在MySQL Workbench中运行代码时,它执行得很好,没有任何错误。当我检查表时,分区未显示在列表中: enter image description here

在自动生成的DDL中,该分区被注释掉:

CREATE TABLE `TABLE_NAME` (
  `field1` decimal(5,2) DEFAULT NULL,
  `field2` decimal(5,2) DEFAULT NULL,
  `DATE_FIELD` date NOT NULL,
  `field3` float DEFAULT NULL,
  `field4` float DEFAULT NULL,
  `field5` datetime DEFAULT NULL,
  `field6` varchar(50) NOT NULL,
  PRIMARY KEY (`field6`,`DATE_FIELD`),
  KEY `dd_IDX1` (`DATE_FIELD`,`field1`,`field2`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1
/*!50100 PARTITION BY RANGE (year(`DATE_FIELD`))
(PARTITION y1 VALUES LESS THAN (2017) ENGINE = InnoDB,
 PARTITION y2 VALUES LESS THAN (2018) ENGINE = InnoDB,
 PARTITION y3 VALUES LESS THAN (2019) ENGINE = InnoDB,
 PARTITION ymax VALUES LESS THAN (2050) ENGINE = InnoDB) */

我不知道为什么会这样。我加载了一些伪造的记录,以查看是否由于缺少数据而导致了该问题。我还尝试注释掉分区并创建了一个没有运气的新表。

2 个答案:

答案 0 :(得分:0)

经过更多研究,我将总结一个事实,即在Table Table Inspector中单击GUI中的错误时,分区不会显示在“分区”屏幕中。当您选择“ Alter Table”并查看“分区”选项卡时,它们会显示在此处。此外,在检查PARTITIONS信息表时,分区也会显示在此处。请参阅Rick James的答案以了解注释语法。

答案 1 :(得分:0)

/*!50100 ... */是一种特殊的注释。它说:“如果版本是5.1.0或更高版本,则以真实文本形式包含;否则保留为注释。

因此,如果您在5.0服务器上运行它,则它将没有分区。 (5.0尚未实现PARTITIONs。)但5.1及更高版本将实现。

您将在mysqldump输出中看到此变化。

同时,您可能会发现使用PARTITIONing无法获得任何性能。你想要什么?