我的编程空间,编程开发者的网络收藏夹
学习永远不晚

mysql表分区实验总结

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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分区; 

[root@master 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的值必须在分区定义中存在,否则不能插入并报错。

[root@master 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'

mysql表分区实验总结



分区管理--测试总结:

删除分区:
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分区,并且p0,p1的[list]值必须包含在新的分区内,否则不在新区[list]中的数据会丢失;

ALTER TABLE a  REORGANIZE  PARTITION p0,p1,p2 INTO (PARTITION p0 VALUES LESS THAN (500),PARTITION p1 VALUES LESS THAN maxvalue);  --重定义分区结构:将Range分区p1,p2合并到p0分区,由于原p2分区是maxvalue值,所以还得同时增加一个新的maxvalue分区,否则报错。

拆分分区:



添加分区:

未有分区的情况下:
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值也被删除,后面无法往表中插入该值的数据。


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

mysql表分区实验总结

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Git分支管理实践:项目经验总结

在软件开发过程中,代码的分支管理是非常重要的。Git分支管理是现代软件开发中十分重要的一环。Git的分支管理机制使得开发人员可以在更安全的环境下进行并行开发、版本控制和持续集成等工作。然而,尽管Git很强大,但假如分支无序管理或者没有遵守相
Git分支管理实践:项目经验总结
2023-11-04

Git分支管理最佳实践经验总结

Git分支管理最佳实践经验总结Git是目前最流行的版本控制工具之一,它通过分支管理极大地简化了团队协作开发过程中的工作流。然而,分支管理的复杂性可能会导致开发者陷入困境。本文将介绍几种基本的分支管理策略,以帮助开发团队更好地利用Git来协调
Git分支管理最佳实践经验总结
2023-11-03

el-form表单验证的一些实用方法总结

表单校验是注册环节中必不可少的操作,表单校验通过一定的规则来确保用户提交数据的有效性,下面这篇文章主要给大家介绍了关于el-form表单验证的一些实用方法,需要的朋友可以参考下
2023-01-04

Git开发实战:项目经验分享与总结

Git是一款分布式版本控制系统,广泛应用于软件开发领域。在实际的项目开发中,合理利用Git进行团队协作和版本管理,能够极大地提高开发效率和项目质量。本文将分享我在Git开发中的实战经验,并总结一些注意事项和技巧,希望对读者有所启发和帮助。一
Git开发实战:项目经验分享与总结
2023-11-04

mysql分区表:日期分区

mysql分区表:日期分区 1.创建分区表2.查看分区3.添加分区4.存储过程:分区删除与创建5.事件定时6.触发器设计:子表每插入一行,总表获得一行7.创建索引8.添加枚举型字段 1.创建分区表 CREATE TAB
2023-08-21

编程热搜

目录