一、维护分区
对于表的维护,我们一般有如下几种方式: CHECK table,OPTIMIZE table,ANALYZE table和REPAIR table。
而这几种方式,对于分区同样适用。下面,我们一一阐述各种的作用。
1. Rebuilding partitions
重建分区,它相当于先删除分区中的数据,然后重新插入。这个主要是用于分区的碎片整理。
譬如:
ALTER table t1 REBUILD PARTITION p0,p1;
2. Optimizing partitions
该命令主要是用于回收空闲空间和分区的碎片整理。对分区执行该命令,相当于依次对分区执行 CHECK PARTITION,ANALYZE PARTITION,REPAIR PARTITION命令。
譬如:
table t1 OPTIMIZE PARTITION p0,p1;
注意:
一些存储引擎,譬如InnoDB,并不支持基于分区的Optimizing。当你执行该命令时,会rebuild整张表,在 MysqL 5.6.9版本以上,执行该命令会导致整张表被rebuild和analyze。在这种情况下,建议直接使用 ALTER table ... REBUILD PARTITION 或 ALTER table ... ANALYZE PARTITION。
3. Analyzing partitions
读取和存储分区中值的分布情况
table t1 ANALYZE PARTITION p3;
4. Repairing partitions
修复被破坏的分区
table t1 REPAIR PARTITION p0,1)">5. Checking partitions检查分区是否存在错误
table trb3 CHECK PARTITION p1;注意:
1> MysqLcheck和myisamchk并不支持分区表
2> 上述分区名也可用all替代,指的是对所有分区进行 *** 作。
3> ANALYZE,CHECK,OPTIMIZE,REBUILD,REPAIR和TruncATE命令并不适用于子分区。
二、如何获取分区的相关信息
1. 通过 SHOW CREATE table 语句来查看分区表的分区子句
譬如:
MysqL> show create table e\G*************************** 1. row *************************** table: eCreate table: CREATE table `e` ( `ID` int(11) NOT NulL,`fname` varchar(30) DEFAulT ) ENGINE=InnoDB DEFAulT CHARSET=latin1/*!50100 PARTITION BY RANGE (ID)(PARTITION p0 VALUES LESS THAN (50) ENGINE = InnoDB,PARTITION p1 VALUES LESS THAN (100) ENGINE = InnoDB,PARTITION p2 VALUES LESS THAN (150) ENGINE = InnoDB,PARTITION p3 VALUES LESS THAN MAXVALUE ENGINE = InnoDB) */1 row in set (0.00 sec)2. 通过 SHOW table STATUS 语句来查看表是否分区
对应Create_options字段,譬如:
MysqL status\G*************************** name: e Engine: InnoDB Version: 10 Row_format: Compact Rows: 6 Avg_row_length: 10922 Data_length: 65536Max_data_length: 0 Index_length: Data_free: auto_increment: Create_time: 2015-1207 22:26:06 Update_time: Check_time: Collation: latin1_swedish_ci Checksum: Create_options: partitioned Comment:3. 查看 informatION_SCHEMA.PARTITIONS表
4. 通过 EXPLAIN PARTITIONS SELECT 语句查看对于具体的SELECT语句,会访问哪个分区。
三、分区交换
分区交换的语法如下:
table pt EXCHANGE PARTITION p WITH table nt其中,pt是分区表,p是pt的分区(注:也可以是子分区),nt是目标表。
其实,分区交换的限制还是蛮多的:
1> nt不能为分区表
2> nt不能为临时表
3> nt和pt的结构必须一致
4> nt不存在任何外键约束,即既不能是主键,也不能是外键。
5> nt中的数据不能位于p分区的范围之外。
具体可参考MysqL的官方文档
http://dev.mysql.com/doc/refman/5.6/en/partitioning-management-exchange.html
总结
以上是内存溢出为你收集整理的MySQL分区表的管理~2全部内容,希望文章能够帮你解决MySQL分区表的管理~2所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)