zoukankan      html  css  js  c++  java
  • MYSQL 子分区详解

    子分区

    子分区是分区表中每个分区的再次分割。例如,考虑下面的CREATE TABLE语句:

    CREATE TABLE ts (id INT, purchased DATE)  
     PARTITION BY RANGE(YEAR(purchased)) 
      SUBPARTITION BY HASH(TO_DAYS(purchased))  
       SUBPARTITIONS 2(  
         PARTITION p0 VALUES LESS THAN (1990),   
         PARTITION p1 VALUES LESS THAN (2000),   
         PARTITION p2 VALUES LESS THAN MAXVALUE
         );

    表ts有3个RANGE分区。这3个分区中的每一个分区——p0, p1, 和 p2——又被进一步分成了2个子分区。实际上,整个表被分成了3 * 2 = 6个分区。但是,由于PARTITION BY RANGE子句的作用,这些分区的头2个只保存“purchased”列中值小于1990的那些记录。

    在MySQL 5.1中,对于已经通过RANGE或LIST分区了的表再进行子分区是可能的。子分区既可以使用HASH希分区,也可以使用KEY分区。这也被称为复合分区(composite partitioning)。

    为了对个别的子分区指定选项,使用SUBPARTITION子句来明确定义子分区也是可能的。

    例如,创建在前面例子中给出的同一个表的、一个更加详细的方式如下:

    CREATE TABLE ts (id INT, purchased DATE)  
     PARTITION BY RANGE(YEAR(purchased))   
     SUBPARTITION BY HASH(TO_DAYS(purchased))
        (
        PARTITION p0 VALUES LESS THAN (1990) 
              (SUBPARTITION s0,  
              SUBPARTITION s1 ),     
          PARTITION p1 VALUES LESS THAN (2000)  
               (SUBPARTITION s2,
                  SUBPARTITION s3 ),   
           PARTITION p2 VALUES LESS THAN MAXVALUE   
                  (SUBPARTITION s4,
                   SUBPARTITION s5)  
               );

    几点要注意的语法项:

    ·    每个分区必须有相同数量的子分区。

    ·   如果在一个分区表上的任何分区上使用SUBPARTITION来明确定义任何子分区,那么就必须定义所有的子分区。换句话说,下面的语句将执行失败:

    CREATE TABLE ts (id INT, purchased DATE)
     PARTITION BY RANGE(YEAR(purchased))
      SUBPARTITION BY HASH(TO_DAYS(purchased))
       (
          PARTITION p0 VALUES LESS THAN (1990)
              ( SUBPARTITION s0,
                 SUBPARTITION s1),
           PARTITION p1 VALUES LESS THAN (2000),
            PARTITION p2 VALUES LESS THAN MAXVALUE
            (
            SUBPARTITION s2,
            SUBPARTITION s3
            )
       );

    即便这个语句包含了一个SUBPARTITIONS 2子句,但是它仍然会执行失败。

    每个SUBPARTITION子句必须包括 (至少)子分区的一个名字。否则,你可能要对该子分区设置任何你所需要的选项,或者允许该子分区对那些选项采用其默认的设置。·

     在每个分区内,子分区的名字必须是唯一的,但是在整个表中,没有必要保持唯一。例如,下面的CREATE TABLE语句是有效的:

     CREATE TABLE ts (id INT, purchased DATE)
      PARTITION BY RANGE(YEAR(purchased))
      SUBPARTITION BY HASH(TO_DAYS(purchased))
      (
      PARTITION p0 VALUES LESS THAN (1990)
       (
        SUBPARTITION s0,
         SUBPARTITION s1
         ),
         PARTITION p1 VALUES LESS THAN (2000)
         (
          SUBPARTITION s0,
          SUBPARTITION s1
          ),
           PARTITION p2 VALUES LESS THAN MAXVALUE
            (
            SUBPARTITION s0,
            SUBPARTITION s1
            )
       );

    转载 :http://dev.mysql.com/doc/refman/5.1/zh/partitioning.html#partitioning

  • 相关阅读:
    poj 3243 Clever Y(BabyStep GiantStep)
    poj 2417 Discrete Logging
    poj 3481 Double Queue
    hdu 4046 Panda
    hdu 2896 病毒侵袭
    poj 1442 Black Box
    hdu 2815 Mod Tree
    hdu 3065 病毒侵袭持续中
    hdu 1576 A/B
    所有控件
  • 原文地址:https://www.cnblogs.com/future2012lg/p/2987661.html
Copyright © 2011-2022 走看看