您的位置
主页 > 网站技术 > 数据库 > » 正文

MySql数据分区操作之新增分区操作

来源: 锦尚中国 点击:

如果想在已经建好的表上进行分区,如果使用alter添加分区的话,mysql会提示错误:

复制代码 代码如下:


ERROR 1505 <HY000> Partition management on a not partitioned table is not possible


正确的方法是新建一个具有分区的表,结构一致,然后用insert into 分区表 select * from 原始表;

测试创建分区表文件

复制代码 代码如下:


CREATE TABLE tr (id INT, name VARCHAR(50), purchased DATE)
PARTITION BY RANGE(YEAR(purchased))
(
    PARTITION p0 VALUES LESS THAN (1990),
    PARTITION p1 VALUES LESS THAN (1995),
    PARTITION p2 VALUES LESS THAN (2000),
    PARTITION p3 VALUES LESS THAN (2005)
);


插入测试数据

复制代码 代码如下:


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


查询P2中的数据

复制代码 代码如下:


select * from tr where purchased between '1995-01-01′ and '2004-12-31′;


如果删除P2,在删除P2分区的同时,也会将其下的所有数据删除

复制代码 代码如下:




首页  - 关于站长圈  - 广告服务  - 联系我们  - 关于站长圈  - 网站地图  - 版权声明