mysql表分区实验总结

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql表分区实验总结相关的知识,希望对你有一定的参考价值。

mysql表分区技术能有效解决水平拆分和垂直拆分的不足,可操作性和效率都更优。以下是一些实验总结。


InnoDB引擎需先在配置文件中设置: innodb_file_per_table=1

--innodb : 主表.frm 保存表结构和分区数目一致的 .ibd 文件,用于保存数据和索引

--myisam:主表.frm保存表结构定义,主表.par保存分区信息,  和分区数目一致的 .MYD文件,用于保存数据,.MDI文件用于索引。

range分区:

CREATE TABLE a(   

id INT PRIMARY KEY AUTO_INCREMENT,

NAME CHAR(20))ENGINE=INNODB CHARSET=utf8

PARTITION BY RANGE(id)(

PARTITION p1 VALUES  LESS THAN (100),

PARTITION p2 VALUES  LESS THAN (200),

PARTITION p3 VALUES  LESS THAN (300),

PARTITION p4 VALUES  LESS THAN  MAXVALUE);


 ----------建立一个以id 区间来划分的分别,当id 小于100时数据保存到p1分区,100到199时保存到p2分区,200到299时保存到p3分区,大于300时保存到p4分区; 

[[email protected] test]#dir

a.frm  a#P#p1.ibd  a#P#p2.ibd  a#P#p4.ibd  db.opt 





List分区:


CREATE TABLE bc(

id INT NOT NULL AUTO_INCREMENT,

par_no INT NOT NULL DEFAULT '1',

a_name CHAR(20) NOT NULL,

PRIMARY KEY(id,par_no)) ENGINE=MYISAM CHARSET=gbk PARTITION BY LIST(par_no)(

PARTITION p0 VALUES IN (10,20,30),

PARTITION p1 VALUES IN (40,50,60),

PARTITION p2 VALUES IN (70,80,100));

---插入数据时,par_no的值必须在分区定义中存在,否则不能插入并报错。

[[email protected] test]# dir nb*

nb.frmnb.parnb#P#p0.MYD  nb#P#p0.MYI  nb#P#p1.MYD  nb#P#p1.MYI  nb#P#p2.MYD  nb#P#p2.MYI  nb#P#p3.MYD  nb#P#p3.MYInb#P#p4.MYD  nb#P#p4.MYI


提示警告:意思大概mysql分区以后的版本不支持myisam引擎吧,换成innodb就可以了。

Warning Code : 1287

The partition engine, used by table 'test.bc', is deprecated and will be removed in a future release. Please use native partitioning instead.

           
Hash分区:


CREATE TABLE nb(

id INT NOT NULL AUTO_INCREMENT,

par_no INT NOT NULL DEFAULT '1',

a_name CHAR(20) NOT NULL,

PRIMARY KEY(id,par_no)) ENGINE=MYISAM CHARSET=gbk PARTITION BY HASH(id)

PARTITIONS 5;           --partition 多了个s ,让mysql自动id的Hash 值存储到5个分区里。


查询分区表中存在的数据量:

SELECT PARTITION_NAME,PARTITION_METHOD,PARTITION_EXPRESSION,PARTITION_DESCRIPTION,TABLE_ROWS,SUBPARTITION_NAME,SUBPARTITION_METHOD,SUBPARTITION_EXPRESSION 

FROM information_schema.PARTITIONS WHERE TABLE_SCHEMA=SCHEMA() AND TABLE_NAME='bcd'

技术分享图片



分区管理--测试总结:

删除分区:
ALTER TABLE tablename REMOVE PARTITIONING ; --
ALTER TABLE bc DROP PARTITION p1;           --

修改分区:
ALTER TABLE nb PARTITION BY HASH(id) PARTITIONS 2;  --按两个hash分区进行重新整理数据;

合并分区:
ALTER TABLE  bc  REORGANIZE  PARTITION   p1,p0 INTO ( PARTITION p6 VALUES IN (10,20,30,40));  --将BC表中的p0,p1分区合并到p6分区;

添加分区:

未有分区的情况下:
ALTER TABLE nb PARTITION BY HASH(id) PARTITIONS 2; --用id 列给表分两个hash分区;如果有unique键,要先删除.

ALTER TABLE a  PARTITION BY RANGE(id)(            --a 表无分区.
PARTITION p0  VALUES LESS THAN (1000),
PARTITION p1  VALUES  LESS THAN (2000),
PARTITION  p2  VALUES LESS THAN  maxvalue)
--------------------------------------------------------------------

ALTER TABLE bc  PARTITION BY LIST(par_no) (PARTITION p1             ----为未定义分区表的BC表添加两个list分区;
VALUES IN (10,20,30),PARTITION p2 VALUES IN (40,50,60,70,80));


已有分区的情况下:
ALTER TABLE abc  REORGANIZE  PARTITION  p2 INTO (
PARTITION p2 VALUES LESS THAN (6000),PARTITION p3 VALUES LESS THAN maxvalue);           --重新定义Range分区p2,并新加一个p3分区,p2分区的析值不能小于现有的最大值,且须新境一个包含最大值(Maxvalue)的新分区,否则报错

ALTER TABLE bc  ADD PARTITION  (PARTITION p3 VALUES IN (20,30));--添加一个list分区

ALTER TABLE nb ADD PARTITION PARTITIONS 2;  --(Hash分区),新加后现有分区里的数据会平滑分摊到新分区,myisam引擎在上面的查询语句中可以体现出来,innodb引擎则计数信息丢失,从0开始重新计数,但表中数据变不会丢失.

注意:删除分区同时会将分区中的数据删除,同时枚举的list值也被删除,后面无法往表中插入该值的数据。


以上是关于mysql表分区实验总结的主要内容,如果未能解决你的问题,请参考以下文章

MySQL分区总结

关于mysql的分区,分表,集群

MySQL分区表简介

Mysql --学习:大量数据快速导入导出

MySQL 表数据分区,每10000条数据自动分区

第十四周课程总结&实验报告