您现在的位置是:群英 > 数据库 > MySQL数据库
MySQL分区表的应用场景、限制、原理、类型及使用是怎样
Admin发表于 2022-09-14 17:54:54872 次浏览
在这篇文章中我们会学习到关于“MySQL分区表的应用场景、限制、原理、类型及使用是怎样”的知识,小编觉得挺不错的,现在分享给大家,也给大家做个参考,希望对大家学习或工作能有帮助。下面就请大家跟着小编的思路一起来学习一下吧。

对于用户而言,分区表是一个独立的逻辑表,但是底层是由多个物理子表组成。分区表对于用户而言是一个完全封装底层实现的黑盒子,对用户而言是透明的,从文件系统中可以看到多个使用#分隔命名的表文件。
mysql在创建表时使用partition by子句定义每个分区存放的数据,在执行查询的时候,优化器会根据分区定义过滤那些没有我们需要数据的分区,这样查询就无须扫描所有分区。
分区的主要目的是将数据安好一个较粗的力度分在不同的表中,这样可以将相关的数据存放在一起。
接下来,我将从以下6个方面来谈谈分区表,分别是分区表的应用场景、分区表的限制、分区表的原理、分区表的类型、如何使用分区表、在使用分区表的时候需要注意的问题。

一、分区表的应用场景

1、表非常大以至于无法全部都放在内存中,或者只在表的最后部分有热点数据,其他均是历史数据。

2、分区表的数据更容易维护

(1)批量删除大量数据可以使用清除整个分区的方式

(2)对一个独立分区进行优化、检查、修复等操作

3、分区表的数据可以分布在不同的物理设备上,从而高效地利用多个硬件设备

4、可以使用分区表来避免某些特殊的瓶颈

(1)innodb的单个索引的互斥访问

(2)ext3文件系统的inode锁竞争

5、可以备份和恢复独立的分区

二、分区表的限制

1、一个表最多只能有1024个分区,在5.7版本的时候可以支持8196个分区

2、在早期的mysql中,分区表达式必须是整数或者是返回整数的表达式,在mysql5.5中,某些场景可以直接使用列来进行分区。

3、如果分区字段中有主键或者唯一索引的列,那么所有主键列和唯一索引列都必须包含进来。

4、分区表无法使用外键约束

三、分区表的原理

分区表由多个相关的底层表实现,这个底层表也是由句柄对象标识,我们可以直接访问各个分区。存储引擎管理分区的各个底层表和管理普通表一样(所有的底层表都必须使用相同的存储引擎),分区表的索引知识在各个底层表上各自加上一个完全相同的索引。从存储引擎的角度来看,底层表和普通表没有任何不同,存储引擎也无须知道这是一个普通表还是一个分区表的一部分。分区表的操作按照以下的操作逻辑进行:

1、select查询

当查询一个分区表的时候,分区层先打开并锁住所有的底层表,优化器先判断是否可以过滤部分分区,然后再调用对应的存储引擎接口访问各个分区的数据

2、insert操作

当写入一条记录的时候,分区层先打开并锁住所有的底层表,然后确定哪个分区接受这条记录,再将记录写入对应底层表。

3、delete操作

当删除一条记录时,分区层先打开并锁住所有的底层表,然后确定数据对应的分区,最后对相应底层表进行删除操作。

4、update操作

当更新一条记录时,分区层先打开并锁住所有的底层表,mysql先确定需要更新的记录再哪个分区,然后取出数据并更新,再判断更新后的数据应该再哪个分区,最后对底层表进行写入操作,并对源数据所在的底层表进行删除操作。

有些操作时支持过滤的,例如,当删除一条记录时,MySQL需要先找到这条记录,如果where条件恰好和分区表达式匹配,就可以将所有不包含这条记录的分区都过滤掉,这对update同样有效。如果是insert操作,则本身就是只命中一个分区,其他分区都会被过滤掉。mysql先确定这条记录属于哪个分区,再将记录写入对应得曾分区表,无须对任何其他分区进行操作。

虽然每个操作都会“先打开并锁住所有的底层表”,但这并不是说分区表在处理过程中是锁住全表的,如果存储引擎能够自己实现行级锁,例如innodb,则会在分区层释放对应表锁。


感谢各位的阅读,以上就是“MySQL分区表的应用场景、限制、原理、类型及使用是怎样”的内容了,通过以上内容的阐述,相信大家对MySQL分区表的应用场景、限制、原理、类型及使用是怎样已经有了进一步的了解,如果想要了解更多相关的内容,欢迎关注群英网络,群英网络将为大家推送更多相关知识点的文章。

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

标签: mysql
相关信息推荐
2022-11-03 17:56:35 
摘要:mysql有触发器。MySQL触发器是存储在数据库目录中的一组SQL语句集合,是MySQL中管理数据的有力工具,主要用于保护表中的数据。MySQL支持三种触发器:1、INSERT触发器,是在INSERT语句执行之前或之后响应的触发器;2、UPDATE触发器,是在UPDATE语句执行之前或之后响应的触发器;3、DELETE触发器,是在DELETE语句执行之前或之后响应的触发器。
2021-11-08 17:46:25 
摘要:这篇文章主要介绍oracle中注释符号的内容,对新手学习oracle中注释符号的使用有一定的帮助,感兴趣的朋友可以了解看看,希望大家阅读完这篇文章能有所收获,接下来跟随小编一起来学习一下吧。
2022-05-07 17:43:40 
摘要:mysql中,可用“concat(round(sum(DATA_LENGTH/1024/1024),2),'M')”语句配合“where table_schema='数据库名称' AND table_name='表名称'”语句查询表的大小。
群英网络助力开启安全的云计算之旅
立即注册,领取新人大礼包
  • 联系我们
  • 24小时售后:4006784567
  • 24小时TEL :0668-2555666
  • 售前咨询TEL:400-678-4567

  • 官方微信

    官方微信
Copyright  ©  QY  Network  Company  Ltd. All  Rights  Reserved. 2003-2019  群英网络  版权所有   茂名市群英网络有限公司
增值电信经营许可证 : B1.B2-20140078   粤ICP备09006778号
免费拨打  400-678-4567
免费拨打  400-678-4567 免费拨打 400-678-4567 或 0668-2555555
微信公众号
返回顶部
返回顶部 返回顶部