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;

mysql查询hash分区数据_mysql分区管理 - hash分区相关推荐

  1. mysql 查询前一个月数据_mysql 查询当天、本周,本月,上一个月的数据......

    今天 select * from 表名 where to_days(时间字段名) = to_days(now()); 昨天 SELECT * FROM 表名 WHERE TO_DAYS( NOW( ) ...

  2. mysql 查询指定字段数据_MySQL使用select语句查询指定表中指定列(字段)的数据

    本文介绍mysql数据库中执行select查询语句,查询指定列的数据,即指定字段的数据. 再来回顾一下sql语句中的select语句的语法: select 语句的基本语法: select from w ...

  3. mysql 查询导入的数据_MySql多表查询及数据导入

    MySQL高级 外键(foreign key) 定义 让当前表字段的值在另一个表的范围内选择 语法 foreign key(参考字段名) references 主表(被参考字段名) on delete ...

  4. mysql查询本年的数据_MySql查询当天、本周、本月、本季度、本年的数据

    1.今天 SELECT * FROM 表名 WHERE TO_DAYS(时间字段名) = TO_DAYS(NOW()); 2.昨天 SELECT * FROM 表名 WHERE TO_DAYS(NOW ...

  5. mysql查询特定时间数据视频_mysql查询特定时间段内的数据

    参照文章(mysql查询时间段内数据)进行了操作. 先来建表语句: [sql] view plaincopySETFOREIGN_KEY_CHECKS=0;-- ------------------- ...

  6. 利用计算机管理分区,win7增加磁盘分区教学 利用磁盘管理增加分区

    win7增加磁盘分区教学,利用磁盘管理增加分区.很多用户感觉自己电脑两三个盘太少,想多分出来一两个,第三方软件肯定没有系统自带可靠,快来看看吧! 首先,打开控制面版----管理工具----计算机管理- ...

  7. MySQL查询本年的数据的sql语句

    MySQL查询本年的数据的sql语句: SELECT * FROM 表名 WHERE YEAR(时间字段)=YEAR(NOW());

  8. Mysql查询时间段内数据,并处理相同日期或同类型的数据

    Mysql查询时间段内数据 表如图,表名为demo,表为某库存量的实时更新表 主要数据为:time时间数据,amount库存量数据 Mysql查询时间段内的数据可以用between方法 select ...

  9. mysql语句查询今天的数据_mysql查询当天所有数据sql语句

    mysql查询当天的所有信息: select * from test where year(regdate)=year(now()) and month(regdate)=month(now()) a ...

  10. mysql查询3个表_mysql如何实现多表查询,三个数据表的联合查询?

    在mysql查询语句中,为了实现查询到某些信息,我们会用到多表的联合查询.那么如何去实现三表的联合查询呢?下面我给大家举一个例子,现在 我这里有三个表,一个是文件表wenjian,一个是管理角色表ad ...

最新文章

  1. 19岁大学生网恋被骗318万!见到“女神”后傻了,对方竟有200斤!
  2. java刚工作搭建环境_Java开发环境的搭建
  3. Intellij导入子项目时,maven列表子项目灰色不可用---解决方法
  4. mysql怎么禁止远程连接_mysql禁止远程访问
  5. 阅读源码的 4 个绝技,我必须分享给你!
  6. 004-全局应用程序类Global.asax
  7. Lumen 5.4 时区设置
  8. 127.0.0.1 zxt.php,恭喜您!序列号购买成功!
  9. 01背包问题—动态规划求解
  10. python的装饰器迭代器与生成器_详解python中的生成器、迭代器、闭包、装饰器
  11. 蔡学镛告诉我们—做好技术PPT的要点
  12. XYPC一款实用的平面测量控制网平差软件
  13. 20200701——mybatis #与$
  14. crontab命令格式详细说明与常用各种写法总结
  15. emouse思·睿—评论与观点整理之二
  16. Linux多线程学习 - sched_yield() CPU让权
  17. matlab第四章图像复原与重建
  18. bg算法 matlab,求助大神,有关BG算法
  19. 在Linux中查找文件系统类型的7种方法(ext2,ext3或ext4)
  20. 众昂矿业:为保障萤石足量供应,开源节流势在必行

热门文章

  1. iPhone11因便宜销量超预期;三星手机曝高危漏洞;xUtils 3.8.3发布 | 极客头条
  2. 荣耀赵明 “Diss” 5G 手机;甲骨文创始人埃里森:Uber 一文不值;Chrome 77 发布 | 极客头条...
  3. “Hyperledger Fabric 是假区块链!”
  4. 披着 Chromium 皮的微软 Edge 浏览器到底长什么样?
  5. 开源项目的所有者去世了怎么办?
  6. Redis 性能问题排查:slowlog 和排队延时
  7. Elasticsearch基础(三)索引和文档操作
  8. mysql循环建表_MySQL循环建表和结合两表的update
  9. Reflect对象的设计目的有这样几个
  10. 深入理解继承知识(下)