2019独角兽企业重金招聘Python工程师标准>>>

hash分区的目的是将数据按照某列进行hash计算后更加均匀的分散到各个分区,相比,range和list分区来说,hash分区不需要明确指定一个给定的列值或者列值集合

应该在保存在哪个分区,mysql会自动按照hash计算后完成这些工作,我们只需要基于将要进行hash的列值指定一个列或者表达式,以及可选的指定要分区的表总的分区数量。

下面我们举一个例子来说,hash分区如何创建。首先我们创建如下的表格:hash_partition_tbl,并插入几条记录到表中,如下所示:

我们也同时看一下,对应的表空间文件是如何分布的(注意,我们已经设置了innodb_file_per_table=1,即每个表单独一个ibd文件),我们在对应的datadir目录下可以看到:

由于我们是分成4个hash区,因此可以看到四个表空间文件,分别是hash_partition_tab#p#pi.ibd,i=0,1,2,3。

这里的hash分区的确定按照如下规则:

mod(YEAR(‘2012-05-01’),4) = mod (2012,4) = 0, 在分区p0;

mod(YEAR(‘2016-05-01’),4) = mod (2016,4) = 0, 在分区p0;

mod(YEAR(‘2010-05-01’),4) = mod (2010,4) = 2, 在分区p2;

mod(YEAR(‘2011-05-01’),4) = mod (2011,4) = 3, 在分区p3;

因此,我们认为 p0有2个记录,p2和p3分别有1个记录,p1记录数为0,那么接下来我们通过查询information_schema.PARTITIONS表来验证。

之前我们知道range和list分区,如果表中存在primary key或者unique key,则对应分区的列必须是这些key的子集,那么对hash是否有同样的约束呢,字符类型的列是否可以作为hash分区?接下来我们立刻以实验为基础进行验证。

首先把之前的分区先删除掉,执行如下命令:

发现drop partition命令只能用在RANGE和LIST分区中。

现在我们把a设置为unique key,如果成功,则说明hash分区允许非unique key 作为hash的列,执行如下:

说明:如果将要分区的表有一个唯一的键,那么用来作为HASH用户函数的自变数或者主键的column_list的自变数的任意列都必须是那个键的一部分。

下面试一下,字符串列是否可以作为hash分区的列,按照上面的讨论和说明,我们认为是不行的,因为hash的计算本质是mod运算,必须是整数。实验如下:

实验证明:hash的分区必须是整数列。

可以通过下面的命令,进行重新分区:

alter table hash_partition_tbl partition by hash(a) partitions 4;   

转载于:https://my.oschina.net/idiotsky/blog/228641

mysql分区管理 - hash分区相关推荐

  1. mysql查询hash分区数据_mysql分区管理 - hash分区

    hash分区的目的是将数据按照某列进行hash计算后更加均匀的分散到各个分区,相比,range和list分区来说,hash分区不需要明确指定一个给定的列值或者列值集合 应该在保存在哪个分区,mysql ...

  2. MySQL按字符串hash分区_MySQL学习笔记(14):分区

    本文更新于2019-06-30,使用MySQL 5.7,操作系统为Deepin 15.4. 分区类型 可以使用SHOW PLUGINS查看是否安装了分区插件. MySQL创建分区表支持使用大部分存储引 ...

  3. MySQL按字符串hash分区_Mysql分区

    Myisam:多个小表一个聚合表,逻辑上的 Innodb:物理文件的划分 注意事项 Show plugins Show engines Show variables like '%partition% ...

  4. Kudu范围分区、Hash分区、多级分区

    范围分区: 范围分区使用全序的范围分区键对数据行进行分配.(全序是指,集合中的任两个元素之间都可以比较的关系.比如实数中的任两个数都可以比较大小,那么"大小"就是实数集的一个全序关 ...

  5. Linux 磁盘管理-分区管理-磁盘分区【gdisk】gpt分区工具使用介绍

    gdisk -l [设备] gdisk又叫GPT fdisk,算是fdisk的延伸吧,主要使用的是GPT分区类型,用来划分容量大于2T的硬盘. 扩展1:分区类型GPT和MBR.GPT最大支持18EB( ...

  6. db2有主键时默认hash分区_彻底搞懂 MySQL 分区!

    GrimMjxhttps://www.cnblogs.com/GrimMjx/p/10526821.html 一.InnoDB逻辑存储结构 首先要先介绍一下InnoDB逻辑存储结构和区的概念,它的所有 ...

  7. mysql 主表存hash和子表的名字_【mysql】mysql分表和表分区详解

    为什么要分表和分区? 日常开发中我们经常会遇到大表的情况,所谓的大表是指存储了百万级乃至千万级条记录的表.这样的表过于庞大,导致数据库在查询和插入的时候耗时太长,性能低下,如果涉及联合查询的情况,性能 ...

  8. Mysql分区表概述、分区类型、分区管理

    另有一篇简单易懂的好文章帮助学习 Mysql分区表的原理和优缺点以及注意点 一.分区概述 分区是指根据一定的规则,数据库把一个表分解成多个更小的.更容易管理的部分.分区有利于管理非常大的表. MySQ ...

  9. mysql hash分区 数目_MySQL 分区

    MySQL 分区 分区是指根据一定的规则,把一个表分解成多个更小更易管理的部分,逻辑上只有一个表或一个索引, 但是实际上该表可能由数个物理分区对象组成,每个分区都是一个独立的对象,每个分区可以独自处理 ...

最新文章

  1. Andriod anim alpha中的属性介绍
  2. 服务器网站数据用什么方式加以保留?
  3. 使用Prometheus监控Linux系统各项指标
  4. VC6重载字体对话框,去除颜色下拉框
  5. 机器学习经典算法具体解释及Python实现--K近邻(KNN)算法
  6. Dwg,png,jpg,Dxf格式转换
  7. qq linux五笔输入法下载官网,QQ五笔输入法下载_QQ五笔输入法下载2021官方下载-太平洋下载中心...
  8. 电气EPLAN电气图纸设计
  9. OK6410A 之 SPI 驱动 测试 步骤
  10. 基于OAI协议元数据收割的.NET资源
  11. nifty bootstrap_nifty admin_nifty admin 下载-一个高端的bootstrap后台管理模板
  12. Minimum spanning tree
  13. C语言读取wav文件
  14. Tita OKRs-E 使OKR成为您企业DNA一部分
  15. 细数中国历史上的十大乱世枭雄(上)
  16. Serv-U 安装配置以及外网访问使用
  17. java重绘jbutton_用Java着色JButton
  18. TCP协议的三次握手和四次挥手
  19. kaggle篇章二,新手入门泰坦尼克号的幸存者预测实验的超详细全过程记录
  20. BeanFactory源码体系解析--AutowireCapableBeanFactory二

热门文章

  1. python安装成功的图标_安装Python
  2. python string转int_Python int与string之间的转化
  3. ajax将数据显示在class为content的标签中_[原创]数据可视化实战项目
  4. ubuntu 命令行torrent种子下载
  5. idea中Terminal输入命令git log后如何退出
  6. 真正的Go编译器与链接器在哪里?
  7. 【BZOJ28431180】极地旅行社,LCT练习
  8. 2017.10.25 打鼹鼠 思考记录
  9. 2017.10.23 卡牌游戏 失败总结
  10. 80486/486/Intel486 架构/流水线及其优化