New partition operation for MySql data partition operation
- 2020-09-16 07:49:06
- OfStack
If you want to partition on an already built table, mysql will give you an error if you add partitions using alter:
ERROR 1505 <HY000> Partition management on a not partitioned table is not possible
The correct method is to create a new table with partition, structure 1, and then use insert into partition table select * from original table;
Test creates partition table files
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 test data
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 ' );
Query the data in P2
select * from tr where purchased between '1995-01-01 ' and '2004-12-31 ' ;
If you delete P2, deleting the P2 partition also deletes all the data under it
alter table tr drop partition p2;
show create table tr;
CREATE TABLE `tr` (
`id` int(11) DEFAULT NULL,
`name` varchar(50) DEFAULT NULL,
`purchased` date DEFAULT NULL
) ENGINE=MyISAM DEFAULT CHARSET=utf8
/*!50100 PARTITION BY RANGE (YEAR(purchased))
(PARTITION p0 VALUES LESS THAN (1990) ENGINE = MyISAM,
PARTITION p1 VALUES LESS THAN (1995) ENGINE = MyISAM,
PARTITION p3 VALUES LESS THAN (2005) ENGINE = MyISAM) */
When the data is inserted again, the data from the original P2 is inserted into P3
INSERT INTO tr VALUES (11, 'pencil holder', '1995-07-12 ' );
ALTER TABLE tr DROP PARTITION p3;
SELECT * FROM tr WHERE purchased BETWEEN '1995-01-01 ' AND '2004-12-31 ' ;
Create a new test table
CREATE TABLE members (
id INT,
fname VARCHAR(25),
lname VARCHAR(25),
dob DATE
)
PARTITION BY RANGE(YEAR(dob)) (
PARTITION p0 VALUES LESS THAN (1970),
PARTITION p1 VALUES LESS THAN (1980),
PARTITION p2 VALUES LESS THAN (1990)
);
Use alter table tablename add partition to add the partition at the end
ALTER TABLE members ADD PARTITION (PARTITION p3 VALUES LESS THAN (2000));
ALTER TABLE members reorganize partition p0 into (
partition m0 values less than (1960),
partition m1 values less than (1970)
);
show create table members;
CREATE TABLE `members` (
`id` int(11) DEFAULT NULL,
`fname` varchar(25) DEFAULT NULL,
`lname` varchar(25) DEFAULT NULL,
`dob` date DEFAULT NULL
) ENGINE=MyISAM DEFAULT CHARSET=utf8
/*!50100 PARTITION BY RANGE (YEAR(dob))
(PARTITION m0 VALUES LESS THAN (1960) ENGINE = MyISAM,
PARTITION m1 VALUES LESS THAN (1970) ENGINE = MyISAM,
PARTITION p1 VALUES LESS THAN (1980) ENGINE = MyISAM,
PARTITION p2 VALUES LESS THAN (1990) ENGINE = MyISAM,
PARTITION p3 VALUES LESS THAN (2000) ENGINE = MyISAM) */
REORGANIZE PARTITION is used to merge and split the data, and the data is not lost.
(detailed reference source: https: / / www ofstack. com article / 42544 htm)
If adding in this way would cause an error, you can only do it in another way, merging and splitting partitions.