文章目录

  • 分区的概念
  • 分区使用场景
  • 分区的限制
  • 为什么要使用分区
  • 分区的类型
  • RANGE分区
  • LIST分区
  • HASH分区
  • 常规HASH分区
  • 线性HASH分区
  • KEY分区
  • 复合分区


分区的概念

分区表是一个独立的逻辑表,但是底层是由多个物理子表组成。
分区的主要目的是将数据按照一个较粗的粒度分布在不同的表中,能够快速过滤掉大量数据,提高查询效率。以及方便对数据进行分区管理等。

分区使用场景

适应网站访问量不大,数据量大,对响应时间有要求的场景可以考虑分区。

mysql分区表的构建 mysql分区表使用场景_mysql分区表的构建

分区的限制

mysql分区表的构建 mysql分区表使用场景_使用场景_02

为什么要使用分区

比如表数据量远大于内存时,索引在空间和维护上的消耗很大,即使用到索引,数据可能也不是按照想要的方式聚集,而且会有大量的碎片产生,最终导致一个查询产生成千上万的随机IO,效率低下,使用分区我们就能快速过滤掉大量不需要的数据,从而提高效率。

分区的类型

RANGE分区

按照表达式值的范围进行分区

RANGE分区详细操作点击这里查看

LIST分区

按照表达式值的集合进行分区

LIST分区详细操作点击这里查看

HASH分区

HASH分区详细操作点击这里查看

常规HASH分区

通过对分区个数进行取模运算,根据得到的余数决定存放在哪一个分区,数据分布相对均匀,但是新增减少分区等操作时,所有数据都要重新计算进行重分布。

线性HASH分区

语法为

PARTITION BY LINEAR HASH( 表达式 ) PARTITIONS num;

线性哈希分区的优点在于增加、删除、合并和拆分分区将变得更加快捷,处理大数据的表比较方便。

KEY分区

KEY分区详细操作点击这里查看

复合分区

基于分区表中的每个分区再次分割。子分区可以是 HASH/KEY 等类型。

参考文章
mysql分区 详解