mysql表分区

分区介绍:

一、什么是分区?

  所谓分区,就是将一个表分成多个区块进行操作和保存,从而降低每次操作的数据,提高性能。而对于应用来说则是透明的,从逻辑上看只有一张表,但在物理上这个表可能是由多个物理分区组成的,每个分区都是独立的对象,可以进行独立处理。

二、分区能干什么?

  1.可以逻辑数据分割,分割数据能够有多个不同的物理文件路径。

  2.可以存储更多的数据,突破系统单个文件最大限制。

  3.提升性能,提高每个分区的读写速度,提高分区范围查询的速度。

  4.可以通过删除相关分区来快速删除数据

  5.通过跨多个磁盘来分散数据查询,从而提高磁盘I/O的性能。

  6.涉及到例如SUM()、COUNT()这样聚合函数的查询,可以很容易的进行并行处理。

  7.可以备份和恢复独立的分区,这对大数据量很有好处。

三、分区能支持的引擎

  MySQL支持大部分引擎创建分区,入MyISAM、InnoDB等;不支持MERGE和CSV等来创建分区。同一个分区表中的所有分区必须是同一个存储引擎。值得注意的是,在MySQL8版本中,MyISAM表引擎不支持分区。

四、确认MySQL支持分区

  从MySQL5.1开始引入分区功能,可以如下方式查看是否支持:

  老版本用:SHOW VARIABLES LIKE '%partition%';

  新版本用:show plugins;

五、分区类型

  1. RANGE分区:基于属于一个给定连续区间的列值,把多行分配给分区。

    例如,可以将一个表通过年份划分成两个分区,2001 -2010年、2011-2020。

  2. LIST分区:类似于RANGE分区,LIST是列值匹配一个离散值集合中的某个值来进行选择。

    比如 根据字段 把值为1、3、5的放到一起,2、4、6的另外放到一起 等等...

  3. HASH分区:基于用户定义的表达式的返回值来进行选择分区,该表达式使用将要插入到表中的这些行的列值来进行计算,这个函数必须产生非负整数值。

  通过HASH运算来进行分区,分布的比较均匀

  4. KEY分区:类似于按HASH分区,由MySQL服务器提供其自身的哈希函数。

  按照KEY进行分区类似于按照HASH分区

六、无论什么类型的分区,都要注意以下问题

  1. 如果表中存在primary key 或者 unique key 时,分区的列必须是paimary key或者unique key的一个组成部分,也就是说,分区函数的列只能从pk或者uk这些key中取子集

  2. 如果表中不存在任何的paimary key或者unique key,则可以指定任何一个列作为分区列

  3. 5.5版本前的RANGE、LIST、HASH分区要求分区键必须是int;MySQL5.5及以上,支持非整形的RANGE和LIST分区,即:range columns 和 list columns (可以用字符串来进行分区)。

七、分区命名

  1. 分区的名字基本上遵循其他MySQL 标识符应当遵循的原则,例如用于表和数据库名字的

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

水月清辉

你的鼓励将是我创造的最大动力。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值