我有一个表,目前是空的,但将装载数亿条记录。在执行此加载之前,我想在表上创建一些分区以提高查询性能并在以后实现更好的删除(只需截断整个分区)。
我正在使用的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中运行代码时,它执行得很好,没有任何错误。当我检查表时,分区未显示在列表中:
在自动生成的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) */
我不知道为什么会这样。我加载了一些伪造的记录,以查看是否由于缺少数据而导致了该问题。我还尝试注释掉分区并创建了一个没有运气的新表。
答案 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
无法获得任何性能。你想要什么?