Mysql分区 - Hash分区

1、Range(范围) – 这种模式允许DBA将数据划分不同范围。例如DBA可以将一个表通过年份划分成三个分区,80年代(1980’s)的数据,90年代(1990’s)的数据以及任何在2000年(包括2000年)后的数据。
2、Hash(哈希) – 这种模式允许DBA通过对表的一个或多个列的Hash Key进行计算,最后通过这个Hash码不同数值对应的数据区域进行分区。例如DBA可以建立一个对表主键进行分区的表。
3、Key(键值) – Hash模式的一种延伸,这里的Hash Key是MySQL系统产生的。
4、List(预定义列表) – 这种模式允许系统通过DBA定义的列表的值所对应的行数据进行分割。例如:DBA建立了一个横跨三个分区的表,分别根据2004年2005年和2006年值所对应的数据。
5、Composite(复合模式) – 很神秘吧,哈哈,其实是以上模式的组合使用而已,就不解释了。举例:在初始化已经进行了Range范围分区的表上,我们可以对其中一个分区再进行hash哈希分区。

结论

  • 分区和未分区占用文件空间大致相同 (数据和索引文件)
  • 如果查询语句中有未建立索引字段,分区时间远远优于未分区时间
  • 如果查询语句中字段建立了索引,分区和未分区的差别缩小,分区略优于未分区。
  • 对于大数据量,建议使用分区功能。
  • 去除不必要的字段
  • 根据手册, 增加myisam_max_sort_file_size 会增加分区性能( mysql重建索引时允许使用的临时文件最大大小)

一、HASH分区

1、要使用哈希分区对表进行分区,必须在CREATETABLE语句中附加PARTITION BY HASH(expr)子句,其中expr是返回整数的表达式。这可以是一个列的名称,其类型是MySQL的整数类型之一。此外,您很可能希望使用PARTITIONS num,其中num是一个正整数,表示要将表划分到的分区数。

2、在HASH分区中,使用表达式expr对分区数num求模MOD(expr,num)来计算数据行的分区号

3、LINEAR HASH与HASH的区别:线性散列,它与常规散列的不同之处在于,线性散列使用线性二次幂算法,而常规散列使用散列函数值的模数

1、创建分区

CREATE TABLE `tesc`.`hash_test`  (
  `id` int NULL,
  `name` varchar(255) NULL,
  `date` datetime NULL 
)
PARTITION BY HASH(id)
PARTITIONS 4;

#线性hash
CREATE TABLE `tesc`.`linear_hash_test`  (
  `id` int NULL,
  `name` varchar(255) NULL,
  `date` datetime NULL 
)
PARTITION BY LINEAR HASH(id)
PARTITIONS 4;

插入测试数据

insert into hash_test(id,`name`,date) values(1,'zhangsan','1990-09-02'),(2,'lisi','2000-09-02'),(3,'wangwu','2011-09-02'),(4,'liuliu','2021-09-02');

Mysql分区 - Hash分区_第1张图片

2、删除分区

ALTER TABLE hash_test COALESCE PARTITION 2;

注意:通过这种删除分区的方式不会将分区中的数据删除
Mysql分区 - Hash分区_第2张图片

3、增加分区

添加3个分区,即从之前的2个分区变为5个分区

ALTER TABLE hash_test ADD PARTITION PARTITIONS 3;

你可能感兴趣的:(mysql,mysql)