一、如何管理RANGE和List分区
以该分区表为例
CREATE table members ( ID INT,fname VARCHAR(25),lname BY RANGE( YEAR(dob) ) ( PARTITION p0 VALUES LESS THAN (197019801990));
1. 删除分区
ALTER table members DROP PARTITION p1;
注意:如果删掉了某分区,则该分区内的数据将全部丢失,不仅如此,在用show create table members\G;命令查看该表的创建语句时将无法看到被删除分区的任何信息。
对于RANGE分区来说,如果删除了p1分区,在插入数据时,如果日期在1970到1980区间之内,则该数据将会被分配到下一个分区,即p2,。
对于List分区,如果删除了某一分区,在插入数据时,如果数据属于这一分区,则插入会报错。
如果只是删除数据而不删除该分区的信息,可使用truncate命令
TruncATE PARTITION p1;
2. 添加分区
ADD PARTITION (PARTITION p3 2000));
注意:使用ADD命令来添加分区,只能在分区列表的末尾添加,具体到本例中,只能添加到1990年以后。
当然,在实际生产环境中,这样的局限性太大,譬如我想将p0分区之前添加一个分区,区间为1960,或者将p1之间再添加一个1975的分区,这时候,用ADD将无法满足此类需求,可使用ALTER table ... REORGANIZE PARTITION命令。
譬如:
table members REORGANIZE PARTITION p0 INTO ( PARTITION s0 1960));
REORGANIZE命令其实是相当灵活的,不仅能拆分分区,还可以用来合并分区,譬如:
table members REORGANIZE PARTITION p0,p1,p2,p3 ( PARTITION m0 2000注意:1> 不能使用REORGANIZE PARTITION命令修改表的分区类型,只能通过ALTER table ... PARTITION BY ....语句,譬如:
members PARTITION BY HASH( (dob) ) PARTITIONS 8;2> REORGANIZE PARTITION语法如下:
tbl_name REORGANIZE PARTITION partition_List INTO (partition_deFinitions);partition_deFinitions中分区的范围必须要涵盖partition_List中的分区范围。
二、如何管理HASH和KEY分区
以该分区表为例
clIEnts ( ID 30MONTH(signed) )PARTITIONS 12;对于HASH分区和KEY分区,并不支持上述RANGE和List分区的语法,譬如DROP,TruncATE,REORGANIZE分区。
事实上,它只支持一种类型的“分区调整”。
table clIEnts COALESCE PARTITION 4;该命令的作用在于将clIEnts表的分区剪裁4个,从12个剪裁到8个。
table clIEnts ADD PARTITION PARTITIONS 6;同样,该命令为clIEnts表增加了6个分区,从12个到18个。
总结以上是内存溢出为你收集整理的MySQL分区表的管理~1全部内容,希望文章能够帮你解决MySQL分区表的管理~1所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)