mysql表分区

创建分区表

  1. CREATE TABLE `表名` (   

  2.     `EQUIPMENTID` char(17) NOT NULL,   

  3.     `ATTRIBUTEID` char(4) NOT NULL,   

  4.     `VALUE` varchar(20) NOT NULL,   

  5.     `COLLECTTIME` datetime NOT NULL  

  6. )    

  7. ENGINE=InnoDB (适用大部分引擎,可根据需要调整)   

  8. DEFAULT CHARSET=gbk(编码可根据需要修改)    

  9. PARTITION BY RANGE (to_days(COLLECTTIME))    

  10. (PARTITION pmin VALUES LESS THAN (to_days('2010-01-01')),   

  11. PARTITION p201001 VALUES LESS THAN (to_days('2010-02-01')) ,    

  12. PARTITION p201002 VALUES LESS THAN (to_days('2010-03-01')) ,   

  13. PARTITION p201003 VALUES LESS THAN (to_days('2010-04-01')) ,    

  14. PARTITION p201004 VALUES LESS THAN (to_days('2010-05-01')) ,   

  15. PARTITION p201005 VALUES LESS THAN (to_days('2010-06-01')) ,    

  16. PARTITION p201006 VALUES LESS THAN (to_days('2010-07-01')) ,   

  17. PARTITION p201007 VALUES LESS THAN (to_days('2010-08-01')) ,    

  18. PARTITION p201008 VALUES LESS THAN (to_days('2010-09-01')) ,   

  19. PARTITION p201009 VALUES LESS THAN (to_days('2010-10-01')) ,    

  20. PARTITION p201010 VALUES LESS THAN (to_days('2010-11-01')),   

  21. PARTITION p201011 VALUES LESS THAN (to_days('2010-12-01')),   

  22. PARTITION p201012 VALUES LESS THAN (to_days('2011-01-01')),   

  23. PARTITION p201101 VALUES LESS THAN (to_days('2011-02-01')),   

  24. PARTITION p201102 VALUES LESS THAN (to_days('2011-03-01')),   

  25. PARTITION p201103 VALUES LESS THAN (to_days('2011-04-01')),   

  26. PARTITION p201104 VALUES LESS THAN (to_days('2011-05-01')),   

  27. PARTITION p201105 VALUES LESS THAN (to_days('2011-06-01')),   

  28. PARTITION p201106 VALUES LESS THAN (to_days('2011-07-01')),   

  29. PARTITION p201107 VALUES LESS THAN (to_days('2011-08-01')),   

  30. PARTITION p201108 VALUES LESS THAN (to_days('2011-09-01')),   

  31. PARTITION p201109 VALUES LESS THAN (to_days('2011-10-01')),   

  32. PARTITION p201110 VALUES LESS THAN (to_days('2011-11-01')),   

  33. PARTITION p201111 VALUES LESS THAN (to_days('2011-12-01')),   

  34. PARTITION p201112 VALUES LESS THAN (to_days('2012-01-01')),   

  35. PARTITION pmax VALUES LESS THAN MAXVALUE );   


为现有表创建分区

  1. alter table 表名   

  2. PARTITION BY RANGE (to_days(COLLECTTIME))    

  3. (PARTITION pmin VALUES LESS THAN (to_days('2010-01-01')),   

  4. PARTITION p201001 VALUES LESS THAN (to_days('2010-02-01')) ,    

  5. PARTITION p201002 VALUES LESS THAN (to_days('2010-03-01')) ,   

  6. PARTITION p201003 VALUES LESS THAN (to_days('2010-04-01')) ,    

  7. PARTITION p201004 VALUES LESS THAN (to_days('2010-05-01')) ,   

  8. PARTITION p201005 VALUES LESS THAN (to_days('2010-06-01')) ,    

  9. PARTITION p201006 VALUES LESS THAN (to_days('2010-07-01')) ,   

  10. PARTITION p201007 VALUES LESS THAN (to_days('2010-08-01')) ,    

  11. PARTITION p201008 VALUES LESS THAN (to_days('2010-09-01')) ,   

  12. PARTITION p201009 VALUES LESS THAN (to_days('2010-10-01')) ,    

  13. PARTITION p201010 VALUES LESS THAN (to_days('2010-11-01')),   

  14. PARTITION p201011 VALUES LESS THAN (to_days('2010-12-01')),   

  15. PARTITION p201012 VALUES LESS THAN (to_days('2011-01-01')),   

  16. PARTITION p201101 VALUES LESS THAN (to_days('2011-02-01')),   

  17. PARTITION p201102 VALUES LESS THAN (to_days('2011-03-01')),   

  18. PARTITION p201103 VALUES LESS THAN (to_days('2011-04-01')),   

  19. PARTITION p201104 VALUES LESS THAN (to_days('2011-05-01')),   

  20. PARTITION p201105 VALUES LESS THAN (to_days('2011-06-01')),   

  21. PARTITION p201106 VALUES LESS THAN (to_days('2011-07-01')),   

  22. PARTITION p201107 VALUES LESS THAN (to_days('2011-08-01')),   

  23. PARTITION p201108 VALUES LESS THAN (to_days('2011-09-01')),   

  24. PARTITION p201109 VALUES LESS THAN (to_days('2011-10-01')),   

  25. PARTITION p201110 VALUES LESS THAN (to_days('2011-11-01')),   

  26. PARTITION p201111 VALUES LESS THAN (to_days('2011-12-01')),   

  27. PARTITION p201112 VALUES LESS THAN (to_days('2012-01-01')),   

  28. PARTITION pmax VALUES LESS THAN MAXVALUE );   


如果表中已有数据,分区时会自动进行分区存储,不必担心数据丢失或者手动分类数据.

删除表中的指定分区

  1. ALTER TABLE 表名 DROP PARTITION 分区名;   



追加表分区

  1. ALTER TABLE 表名 DROP PARTITION pmax;   

  2. ALTER TABLE 表名   

  3. ADD PARTITION (   

  4. PARTITION p201201 VALUES LESS THAN (to_days('2012-2-1')),   

  5. PARTITION pmax VALUES LESS THAN MAXVALUE);   


查看标分区信息

  1. SELECT    

  2.         partition_name part,     

  3.         partition_expression expr,     

  4.         partition_description descr,     

  5.         table_rows     

  6. FROM    

  7.         INFORMATION_SCHEMA.partitions     

  8. WHERE    

  9.         TABLE_SCHEMA = schema()    

  10.         AND TABLE_NAME='表名';   

查看查询语句涉及分区信息

  1. explain partitions   

  2. select … from 表名 where …;   



你可能感兴趣的:(众人众人众人)