MySQL分区表的管理~1

MySQL分区表的管理~1,第1张

概述一、如何管理RANGE和LIST分区 以该分区表为例 1. 删除分区 注意:如果删掉了某分区,则该分区内的数据将全部丢失,不仅如此,在用show create table membersG;命令查看

一、如何管理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所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1151552.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存