mysql partition

mysql partition分为 水平分区 和 垂直分区

  1. 水平分区
    举个简单例子:一个包含十年发票记录的表可以被分区为十个不同的分区,每个分区包含的是其中一年的记录
    几种常见模式:
    • Range()
      这种模式允许DBA将数据划分不同范围
      例如DBA可以将一个表通过年份划分成三个分区,80年代(1980’s)的数据,90年代(1990’s)的数据以及任何在2000年(包括2000年)后的数据
    • Hash(哈希)
      这中模式允许DBA通过对表的一个或多个列的Hash Key进行计算,最后通过这个Hash码不同数值对应的数据区域进行分区
      例如DBA可以建立一个对表主键进行分区的表
    • Key(键值)
      此模式是上面Hash模式的一种延伸,这里的Hash Key是MySQL系统产生的
    • List(预定义列表)
      这种模式允许系统通过DBA定义的列表的值所对应的行数据进行分割.
      例如DBA建立了一个横跨三个分区的表,分别根据2004年2005年和2006年值所对应的数据
    • Composite(复合模式)
      其实是以上模式的组合使用而已
      举例在初始化已经进行了Range范围分区的表上,我们可以对其中一个分区再进行hash哈希分区
  2. 垂直分区
    举个简单例子:一个包含了大text和BLOB列的表,这些text和BLOB列又不经常被访问,这时候就要把这些不经常使用的text和BLOB了划分到另一个分区,在保证它们数据相关性的同时还能提高访问速度

查看分区表和删除分区表

1
2
mysql> SELECT partition_name part,partition_expression expr,partition_description descr,table_rows FROM information_schema.partitions  WHERE table_schema = SCHEMA() AND table_name='table_name';
mysql> alter table table_name drop partition partition_name;

查看表是否分配分区

1
2
mysql> use information_schema;
mysql> select TABLE_SCHEMA,TABLE_NAME,PARTITION_NAME from PARTITIONS where TABLE_SCHEMA='pmsmonitorlog';