mysql 添加分區(分區增刪改)

      若是想在已經建好的表上進行分區,若是使用alter添加分區的話,mysql會提示錯誤: 
        ERROR 1505 <HY000> Partition management on a not partitioned table is not possible 
        正確的方法是新建一個具備分區的表,結構一致,而後用insert into 分區表 select * from 原始表

        測試建立分區表文件mysql

Mysql代碼   收藏代碼
  1. CREATE TABLE tr (id INT, name VARCHAR(50), purchased DATE)  
  2. PARTITION BY RANGE(YEAR(purchased))  
  3. (  
  4.     PARTITION p0 VALUES LESS THAN (1990),  
  5.     PARTITION p1 VALUES LESS THAN (1995),  
  6.     PARTITION p2 VALUES LESS THAN (2000),  
  7.     PARTITION p3 VALUES LESS THAN (2005)  
  8. );  


        插入測試數據sql

Mysql代碼   收藏代碼
  1. INSERT INTO tr VALUES  
  2. (1, 'desk organiser', '2003-10-15'),  
  3. (2, 'CD player', '1993-11-05'),  
  4. (3, 'TV set', '1996-03-10'),  
  5. (4, 'bookcase', '1982-01-10'),  
  6. (5, 'exercise bike', '2004-05-09'),  
  7. (6, 'sofa', '1987-06-05'),  
  8. (7, 'popcorn maker', '2001-11-22'),  
  9. (8, 'aquarium', '1992-08-04'),  
  10. (9, 'study desk', '1984-09-16'),  
  11. (10, 'lava lamp', '1998-12-25');  



        查詢P2中的數據less

Mysql代碼   收藏代碼
  1. select * from tr where purchased between '1995-01-01' and '2004-12-31';  



       若是刪除P2,在刪除P2分區的同時,也會將其下的全部數據刪除測試

Mysql代碼   收藏代碼
  1. alter table tr drop partition p2;  
  2.   
  3. show create table tr;  
  4.   
  5. CREATE TABLE `tr` (  
  6.   `id` int(11) DEFAULT NULL,  
  7.   `name` varchar(50) DEFAULT NULL,  
  8.   `purchased` date DEFAULT NULL  
  9. ) ENGINE=MyISAM DEFAULT CHARSET=utf8  
  10. /*!50100 PARTITION BY RANGE (YEAR(purchased))  
  11. (PARTITION p0 VALUES LESS THAN (1990) ENGINE = MyISAM,  
  12.  PARTITION p1 VALUES LESS THAN (1995) ENGINE = MyISAM,  
  13.  PARTITION p3 VALUES LESS THAN (2005) ENGINE = MyISAM) */  




        再次插入數據時,會將原P2的數據插入至P3中 spa

Mysql代碼   收藏代碼
  1. INSERT INTO tr VALUES (11, 'pencil holder', '1995-07-12');  
  2.   
  3. ALTER TABLE tr DROP PARTITION p3;  
  4.   
  5. SELECT * FROM tr WHERE purchased  BETWEEN '1995-01-01' AND '2004-12-31';  




        建立一個新的測試表 ci

Mysql代碼   收藏代碼
  1. CREATE TABLE members (  
  2.     id INT,   
  3.     fname VARCHAR(25),  
  4.     lname VARCHAR(25),   
  5.     dob DATE  
  6. )  
  7. PARTITION BY RANGE(YEAR(dob)) (  
  8.     PARTITION p0 VALUES LESS THAN (1970),  
  9.     PARTITION p1 VALUES LESS THAN (1980),  
  10.     PARTITION p2 VALUES LESS THAN (1990)  
  11. );  




        直接用alter table tablename add partition 方式再最後面添加分區 string

Mysql代碼   收藏代碼
  1. ALTER TABLE members ADD PARTITION (PARTITION p3 VALUES LESS THAN (2000));  




Mysql代碼   收藏代碼
    1. ALTER TABLE members reorganize partition p0 into (  
    2.     partition m0 values less than (1960),  
    3.     partition m1 values less than (1970)  
    4. );  
    5.   
    6. show create table members;  
    7.   
    8. CREATE TABLE `members` (  
    9.   `id` int(11) DEFAULT NULL,  
    10.   `fname` varchar(25) DEFAULT NULL,  
    11.   `lname` varchar(25) DEFAULT NULL,  
    12.   `dob` date DEFAULT NULL  
    13. ) ENGINE=MyISAM DEFAULT CHARSET=utf8  
    14. /*!50100 PARTITION BY RANGE (YEAR(dob))  
    15. (PARTITION m0 VALUES LESS THAN (1960) ENGINE = MyISAM,  
    16.  PARTITION m1 VALUES LESS THAN (1970) ENGINE = MyISAM,  
    17.  PARTITION p1 VALUES LESS THAN (1980) ENGINE = MyISAM,  
    18.  PARTITION p2 VALUES LESS THAN (1990) ENGINE = MyISAM,  
    19.  PARTITION p3 VALUES LESS THAN (2000) ENGINE = MyISAM) */  
相關文章
相關標籤/搜索