子分区是分区表中,每个分区的再次分割,适合保存非常大量的数据 。
解读:主分区使用RANGE按照年来进行分区,有3个RANGE分区 。这3个分区中又被进一步分成了2个子分区,实际上,整个表被分成了3 * 2 = 6个分区 。每个子分区按照天进行HASH分区 。小于2017的放在一起,2017-2020的放在一起,大于2020的放在一起 。
注意:
(1) 在MySQL5.1中,对于已经通过RANGE或LIST分区了的表在进行子分区是可能的 。子分区既可以使用HASH分区,也可以使用KEY分区 。这也被称为复合分区 。
(2) 每个分区必须有相同数量的子分区 。
(3) 如果在一个分区表上的任何分区上使用SUBPARTITION来明确定义任何子分区,那么就必须定义所有的子分区 。
(4) 每个SUBPARTITION子句必须包含(至少)子分区的一个名字 。
(5) 在每个子分区内,子分区的名字必须是惟一的,目前在整个表中,也要保持唯一 。例如:
子分区可以用于特别大的表,可以在多个磁盘间分配数据和索引 。例如:
九、MySQL分区处理NULL值的方式
十、分区管理概述
可以对分区进行添加、删除、重新定义、合并或拆分等管理操作 。
① RANGE和LIST分区的管理
1. 删除分区语句如:alter table tbl_test drop partition p0;
注意:
(1) 当删除了一个分区,也同时删除了该分区中所有的数据 。
(2) 可以通过show create table tbl_test;来查看新的创建表的语句 。
(3) 如果是LIST分区的话 , 删除的数据不能新增进来 , 因为这些行的列值包含在已经删除了的分区的值列表中 。
2. 添加分区语句如:alter table tbl_test add partition(partition p3 values less than(50));
注意:
(1) 对于RANGE分区的表,只可以添加新的分区到分区列表的最高端 。
(2) 对于LIST分区的表,不能添加已经包含在现有分区值列表中的任意值 。
3. 如果希望能不丢失数据的条件下重新定义分区,可以使用如下语句:
REORGANIZE会对分区的数据进行重构 。
ALTER TABLE tbl_name REORGANIZE PARTITION partition_list INTO(partition_definitions)
(1) 拆分分区如:
ALTER TABLE tbl_name REORGANIZE PARTITION partition_list INTO(partition s0 values less than(5),partition s1 values less than(10));
或者如:
ALTER TABLE tbl_name REORGANIZE PARTITION p0 INTO(partition s0 values in(1,2,3), partition s1 values in(4,5));
(2) 合并分区如:ALTER TABLE tbl_name REORGANIZE PARTITION s0,s1 INTO(partition p0 values in(1,2,3,4,5));
4. 删除所有分区,但保留数据,形式:ALTER TABLE tbl_name remove partitioning;
② HASH和KEY分区的管理
1. 减少分区数量语句如:ALTER TABLE tbl_name COALESCE PARTITION 2;
2. 添加分区数量语句如:ALTER TABLE tbl_name add PARTITION partitions 2;
③ 其他分区管理语句
1. 重建分区:类似于先删除保存在分区中的所有记录 , 然后重新插入它们,可用于整理分区碎片 。如:ALTER table tbl_name REBUILD PARTITION p2,p3;
2. 优化分区:如果从分区中删除了大量的行 , 或者对一个带有可变长度的行(也就是说,有VARCHAR , BLOB或TEXT类型的列)做了许多修改,可以使用 ALTER TABLE tbl_name OPTIMIZE PARTITION来收回没有使用的空间 , 并整理分区数据文件的碎片 。如:ALTER TABLE tbl_name OPTIMIZE PARTITION p2,p3;
3. 分析分区:读取并保存分区的键分布,如:ALTER TABLE tbl_name ANALYZE PARTITION p2,p3;
4. 检查分区:检查分区中的数据或索引是否已经被破坏,如:ALTER TABLE tbl_name CHECK PARTITION p2,p3;
5. 修补分区:修补被破坏的分区,如:ALTER TABLE tbl_name REPAIR PARTITION p2,p3;
推荐阅读
- pc单机游戏下载大全,pc游戏单机版
- 自适应宽度的jquery焦点图代码,js图片自适应
- python制作公文管理系统,python编写文件管理系统
- phpcmsv9文章频道页,phpcms专题
- java语言心形代码 在java上编写心形程序
- 刘浩存什么视频,刘浩存vlog
- java代码需要重新编译,java代码需要重新编译吗
- 联想e420怎么切换显卡,联想e420怎么切换显卡启动
- mysql怎么、建表 mysql怎么建表导入数据