mysql建表怎么分区 mysql数据表分区( 五 )


所引?的字段未必必须是整数类型 , 其他的类型也可以使?,?如:
?表分区,是在表分区的基础上再创建表分区的概念 , 每个表分区下的?表分区个数必须?致 , ?如:
ts表拥有三个范围分区,同时每个分区都各?有两个?分区,所以总共有6个分区
?表分区必须是范围/列表分区+哈希/key?表分区的组合
?表分区也可以显示的指定?表分区的名字,?如:
不同的表分区对NULL值的处理?式不同
对范围表分区来说,如果插?的是NULL值,则将数据放到最?的分区表?
对list表分区来说,?持NULL值的唯?情况就是某个分区的允许值中包含NULL
对哈希表分区和Key表分区来说,NULL值会被当成0值对待
通过alter table命令可以执?增加 , 删除,重新定义 , 合并或者拆分表分区的管理动作
对范围表分区和列表表分区来说,删除?个表分区命令如下:
删除表分区的动作不光会把分区删掉 , 也会把表分区?原来的数据给删除掉
在原分区上增加?个表分区可以通过alter table … add partition语句来完成
但对范围表分区来说,增加的表分区必须在尾部增加 , 在头部或者在中间增加都会失败:
为解决这个问题,可以使?REORGANIZE命令:
对列表表分区来说,只要新增加的分区对应的值在之前的表分区中没有出现过,就可以通过alter table… add partition来增加
当然,也可以通过REORGANIZE命令将之前的多个分区合并成?个或?个分区,但要保持分区值?致:
更复杂的?如将多个分区重组成多个分区:
Mysql分区表Partition一、背景
话说风和日丽的一天,为提高随着业务增长的大表(3510449行吧)的访问效率 , 于是决定对表分区 , 记录如下 。
二、实操
结合业务,若干条记录会集中在一个日期,查询时也往往只查询一个日期内的数据,于是选取分区字段为时间 。
创建分区 比如
CREATE TABLEmessage_all(
idint(10) NOT NULL AUTO_INCREMENT,
......
createtimedatetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间'
PRIMARY KEY ( id , createtime )
) ENGINE=InnoDB DEFAULT CHARSET=utf8
PARTITION BY RANGE (YEAR(createtime))
(PARTITION p2015 VALUES LESS THAN (2016) ENGINE = InnoDB,
PARTITION p2016 VALUES LESS THAN (2017) ENGINE = InnoDB,
PARTITION p2017 VALUES LESS THAN (2018) ENGINE = InnoDB,
PARTITION p2018 VALUES LESS THAN MAXVALUE ENGINE = InnoDB)
不过我们表已经有了当然不能这么建 , 除非你想导一次数据 。
如下操作 :
1、
ALTER TABLE message_all PARTITION BY RANGE (to_days(createtime))
(
PARTITION p2015 VALUES LESS THAN (to_days('2016-01-01')),
PARTITION p2016 VALUES LESS THAN (to_days('2017-01-01')),
PARTITION p2017 VALUES LESS THAN (to_days('2018-01-01')),
PARTITION p2018 VALUES LESS THAN MAXVALUE
);
或者
2、ALTER TABLE message_all PARTITION BY RANGE (YEAR(createtime))
(
PARTITION p2015 VALUES LESS THAN (YEAR('2016-01-01'))
);
然后追加 。
ALTER TABLE message_all ADD PARTITION
(
PARTITION p2016 VALUES LESS THAN (YEAR('2017-01-01')),
PARTITION p2017 VALUES LESS THAN (YEAR('2018-01-01')),
PARTITION p2018 VALUES LESS THAN MAXVALUE
);
这里会有几种错误情况:
1、ALTER TABLE message_all PARTITION BY RANGE (to_days(createtime)) ;
[Err] 1492 - For RANGE partitions each partition must be defined
解释:必须指定至少一个分区 。
2、[Err] 1492 -A PRIMARY KEY must include all columns in the table's partitioning function
解释:分区字段必须是主键之一 。

推荐阅读