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

【SQL应知应会】表分区(四)• MySQL版

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

北京

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

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

看不清楚,换张图片

免费获取短信验证码

【SQL应知应会】表分区(四)• MySQL版

请添加图片描述

欢迎来到爱书不爱输的程序猿的博客, 本博客致力于知识分享,与更多的人进行学习交流

本文收录于SQL应知应会专栏,本专栏主要用于记录对于数据库的一些学习,有基础也有进阶,有MySQL也有Oracle

请添加图片描述

前言

在前面的内容中,【SQL应知应会】表分区(一)• MySQL版【SQL应知应会】表分区(二)• MySQL版【SQL应知应会】表分区(三)• MySQL版中,已经完成了MySQL的表分区方面的大部分知识的学习,如为什么对表进行分区,分区有哪些形式,分区有哪些类型以及每一种类型的语句,分区的注意事项以及适用场景,并且用例子代码演示了MySQL的各种分区

今天这篇内容,将继续进行讲述MySQL的表分区的后续内容,主要包括常见的分区操作,如删除分区、增加分区、分解分区、合并分区、重新定义分区、重建分区、 检查分区、修补分区,不但使用代码进行演示,并且补充了一些需要注意的内容;今天还讲到了MySQL分区表的局限性,其中直接使用错误示例帮助大家更直接明了的看到错误的原因,并且展示了错误修正后的代码

希望文章的内容对大家有所帮助,如果有什么不足的地方,大家可以在评论区或者私信我,感谢大家的支持
那么,快拿出你的电脑,跟着文章一起学习起来吧

一、分区表

1.非分区表

👉:传送门💖非分区表构💖

2.分区表

2.1 概念

👉:传送门💖概念💖

2.2 MySQL数据库表分区

2.2.1 InnoDB 逻辑存储结构

👉:传送门💖InnoDB 逻辑存储结构💖

2.2 段(segment)
2.2.3 区(extent)
2.2.4 页(page)

2.3 MySQL数据库分区的由来

👉:传送门💖MySQL数据库分区的由来💖

2.4 为什么对表进行分区?

👉:传送门💖为什么对表进行分区💖

1 表分区要解决的问题
2.4.2 表分区有如下优点

2.5 MySQL的分区形式

👉:传送门💖MySQL的分区形式💖

1 水平分区(HorizontalPartitioning)
2.5.2 垂直分区(VerticalPartitioning)

2.6 MySQL分区的类型

1 range分区 👉:传送门💖range分区💖
2.6.2 list分区(列表分区)
2.6.3 hash分区
2.6.4 KEY表分区
2.6.5 多字段分区(range、list)
2.6.6 分区注意事项及适用场景
👉:传送门💖2.6.2 ~ 2.6.6💖

2.7 MySQL分区代码

1range分区
2.7.2list分区
👉:传送门💖2.7.1~ 2.7.2💖
2.7.3 hash表分区
2.7.4 key表分区
2.7.5复合分区
2.7.5.1 range-hash(范围哈希)复合分区
2.7.5.2 list-hash(列表哈希)复合分区
👉:传送门💖2.7.3 ~ 2.7.5💖

2.7.5.3 range-key 复合分区

## range-key 复合分区create table foo_emp2 (    empno varchar(20) not null,    empname varchar(20),    deptno int,    salary int )partition by range(salary)subpartition by key(deptno)subpartitions 3(    partition p1 values less than (2000),    partition p2 values less than (3000))insert into foo_emp2 select 1,1,20,1000 from dual

2.7.5.4 list - key 复合分区

## list - key 复合分区create table empk(    empno varchar(20) not null,    empname varchar(20),    deptno int,    birthdate date not null,    salary int )partition by list(deptno)subpartition by key(birthdate)subpartitions 3(    partition p1 values in (10),    partition p2 values in (20))

2.8 常见分区操作

在这里插入图片描述

2.8.1 删除分区

alter table emp drop partition p1## 不能删除hash或者key分区
  • 一次性删除多个分区
alter table emp drop partition p1,p2
  • 删除表的所有分区
alter table emp remove partitioning; -- 不会丢失数据

2.8.2 增加分区

  • 增加范围分区
    • 范围分区一般只能往后增加,往前增加一般得reorganize重新组织分区或者Oracle的split分区
### 范围分区一般只能往后增加,往前增加一般得reorganize重新组织分区或者Oracle的split分区alter table emp add partition(partition 3 values less than (4000))-- 增加完4000的,是否可以增加一个3500?   -- 不可以,因为4000之前的已经划分完了
  • 增加列表分区
alter table emp1 add partition(partiton 3 value in (40))-- 如果前面的list分区中,主分区有3个子分区,那么新增加的这个也会自动给配3个子分区

2.8.3 分解分区

  • Reorganize partition关键字可以对表的部分分区或全部分区进行修改,并且不会丢失数据
  • 分解前后分区的整体范围应该一致
alter table tereorignize partition p1 into(     partition p1 values less than (100),    partition p3 values less than (1000)); -- 不会丢失数据

2.8.4 合并分区

  • Merge分区:把2个分区合并为1个
alter table tereorganize partition p1,p3 into(    partition p1 values less than (1000)) -- 不会丢失数据

2.8.5 重新定义分区

  • 重新定义hash分区表
alter table emp partition by hash(salary) partitions 7;-- 不会丢失数据
  • 重新定义range分区表
alter table emp partition by range(salary)(    partition p1 values less than (2000),    partition p2 values less than (4000)) -- 不会丢失数据

2.8.6 重建分区

  • 这和先删除保存在分区中的所有记录,然后重新插入它们,具有同样的效果
  • 可用于整理分区碎片
alter table emp rebuild partition p1,p2;

2.8.7 检查分区

  • 可以使用几乎与对非分区表使用check table相同的方式检查分区
  • 这个命令可以告知表emp的分区p1,p2中的数据或索引是否已经被破坏,若发生了这种情况,使用修补命令
alter table emp check partition p1,p2;

2.8.8 修补分区

# 修补被破坏的分区alter table emp repairpartition p1,p2

2.9 MySQL分区表的局限性

  • 在5.1版本中分区表对唯一约束有明确的规定,每一个唯一约束必须包含中分区表的分区键(也包括主键约束)

2.9.1 错误示例

报错:MySQL Database Error:A PRIMARY KEY must include allcolums in the tables partitioning function

create table emptt(empno varchar(20) not null,    empname varchar(20),    deptno int,    birthdate date not null,    salary int,    primary key(empno))partition by range(salary) -- 这样的语句会出错:MySQL Database Error:A PRIMARY KEY must include allcolums in the tables partitioning function(    partition p1 values less than (100),    partition p2 values less than (200))

2.9.2 错误修正

create table emptt(empno varchar(20) not null,    empname varchar(20),    deptno int,    birthdate date not null,    salary int,    primary key(empno,salary) -- 在主键中加入salary列就正常)partition by range(salary)(    partition p1 values less than (100),    partition p2 values less than (200))

小结

感谢大家耐心的看完这篇文章,对于SQL在表分区的知识点,我们在MySQL方面已经有四篇内容了,如果大家觉着还算可以,那么就给个三连支持一下吧,如果想要继续关注和学习后续更多的内容,就关注一下爱书不爱输的程序猿吧,当然,如果大家还有什么其他方面的知识点想要看,可以在评论区或者私信我

请添加图片描述

来源地址:https://blog.csdn.net/qq_40332045/article/details/131798977

免责声明:

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

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

【SQL应知应会】表分区(四)• MySQL版

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

下载Word文档

猜你喜欢

【SQL应知应会】表分区(四)• MySQL版

欢迎来到爱书不爱输的程序猿的博客, 本博客致力于知识分享,与更多的人进行学习交流 本文收录于SQL应知应会专栏,本专栏主要用于记录对于数据库的一些学习,有基础也有进阶,有MySQL也有Oracle 分区表 • MySQ
2023-08-16

【SQL应知应会】表分区(五)• MySQL版

欢迎来到爱书不爱输的程序猿的博客, 本博客致力于知识分享,与更多的人进行学习交流 本文收录于SQL应知应会专栏,本专栏主要用于记录对于数据库的一些学习,有基础也有进阶,有MySQL也有Oracle 分区表 • MySQ
2023-08-16

【SQL应知应会】表分区(三)• MySQL版

欢迎来到爱书不爱输的程序猿的博客, 本博客致力于知识分享,与更多的人进行学习交流 本文收录于SQL应知应会专栏,本专栏主要用于记录对于数据库的一些学习,有基础也有进阶,有MySQL也有Oracle 分区表 • MySQ
2023-08-16

【SQL应知应会】表分区(一)• MySQL版

欢迎来到爱书不爱输的程序猿的博客, 本博客致力于知识分享,与更多的人进行学习交流 本文收录于SQL应知应会专栏,本专栏主要用于记录对于数据库的一些学习,有基础也有进阶,有MySQL也有Oracle 分区表 • MySQ
2023-08-20

【SQL应知应会】索引(一)• MySQL版

欢迎来到爱书不爱输的程序猿的博客, 本博客致力于知识分享,与更多的人进行学习交流 本文收录于SQL应知应会专栏,本专栏主要用于记录对于数据库的一些学习,有基础也有进阶,有MySQL也有Oracle 索引 • MySQL
2023-08-16

【SQL应知应会】索引(二)• MySQL版

欢迎来到爱书不爱输的程序猿的博客, 本博客致力于知识分享,与更多的人进行学习交流 本文收录于SQL应知应会专栏,本专栏主要用于记录对于数据库的一些学习,有基础也有进阶,有MySQL也有Oracle 索引 • MySQL
2023-08-16

【SQL应知应会】行列转换(二)• MySQL版

欢迎来到爱书不爱输的程序猿的博客, 本博客致力于知识分享,与更多的人进行学习交流 本文收录于SQL应知应会专栏,本专栏主要用于记录对于数据库的一些学习,有基础也有进阶,有MySQL也有Oracle 行列转换 • Mys
2023-08-25

ORM框架如何适应MySQL的表分区

ORM(对象关系映射)框架是一种编程技术,用于将对象模型表示的数据映射到关系数据库中。当使用ORM框架与MySQL数据库进行交互时,可以通过以下方法适应MySQL的表分区:了解分区策略:在使用ORM框架之前,需要了解MySQL支持的分区类型
ORM框架如何适应MySQL的表分区
2024-10-05

【SQL应知应会】索引(三)• MySQL版:聚簇索引与非聚簇索引;查看索引与删除索引;索引方法

欢迎来到爱书不爱输的程序猿的博客, 本博客致力于知识分享,与更多的人进行学习交流 本文收录于SQL应知应会专栏,本专栏主要用于记录对于数据库的一些学习,有基础也有进阶,有MySQL也有Oracle 索引 • MySQL
2023-08-24

如何实现MySQL底层优化:表分区的应用和优势

如何实现MySQL底层优化:表分区的应用和优势随着大数据时代的到来,数据库的性能需求也越来越高。MySQL作为常用的关系型数据库,为了满足大规模数据存储和高并发访问的需求,提供了表分区的功能。本文将介绍如何实现MySQL底层优化中的表分区,
如何实现MySQL底层优化:表分区的应用和优势
2023-11-08

编程热搜

目录