MySQL 分库分表
创始人
2025-01-10 11:35:27
0

分表

分表

将表按照某种规则拆分成多个表。

分表的使用原因

当数据量超大的时候,B-Tree索引效果很变差。

垂直分区

切分原则:把不常用或存储内容比较多的字段分到新的表中可使表存储更多数据。

原因,Innodb主索引叶子节点存储着当前行的所有信息,所以减少字段可使内存加载更多行数据。

水平分区

切分原则: 增量区间或散列或其他业务逻辑。

使用哪种切分方法要根据实际业务逻辑判断。

范围分区:

比如对表的访问多是近期产生的新数据,历史数据访问较少,可以考虑根据时间增量把数据按照一定时间段(比如每年)切分。

Hash分区:

如果对表的访问较均匀,没有明显的热点区域,则可以考虑用范围(比如每500w一个表)或普通Hash或一致性Hash来切分。

分区表

是什么

分区表是一个独立的逻辑表,但是底层由多个物理子表实现。

为什么

当数据量超大的时候,B-Tree索引就无法起作用了。

MySQL帮我们实现了传统分表后的SQL中间件。

对于原表分区后,对于应用层来说可以不做变化。

分区方式

哈希分区:使用哈希函数将数据均匀分布到不同的分区。

按范围分区:按照时间,地点分区等。

分区的使用场景

对数据的操作只涉及一部分数据,而不是所有数据 

为什么使用了分表

当数据量超大的时候,B-Tree索引就无法有效作用时候。

垂直分表切分原则

把不经常用的字段或者内容多个字段储存到另外一个表,因为InnoDB储存引擎的机制可以储存更多的数据。

水平分表切分原则

表访问的很均匀的话可以使用hash分区,行均匀的分到多表中。

表访问不均匀的话比如查看近期的数据多的话,可以使用按照范围分区。

分库

分库

将数据库的表分到多个数据库中。

分库使用原因

当单台数据库性能不满足需求时,数据库磁盘IO瓶颈和网络IO瓶颈。

分库的原则 

根据业务紧密程度拆分,因为跨数据库无法联表查询。

相关内容

热门资讯

重大通报“免费天天贵阳辅助工具... 重大通报“免费天天贵阳辅助工具”本来存在有挂(辅助挂)详细辅助普及教程1、下载好辅助软件之后点击打开...
透视辅助!hhpoker辅助挂... 透视辅助!hhpoker辅助挂下载,广东闲来辅助,科技教程(有挂辅助);1)广东闲来辅助辅助挂:进一...
第三分钟辅助!禅游破解版苹果版... 第三分钟辅助!禅游破解版苹果版下载(辅助挂)起初真的有挂(详细辅助透牌教程)1.禅游破解版苹果版下载...
透视辅助!微信闲来辅助神器免费... 透视辅助!微信闲来辅助神器免费,闲来山水广西辅助,必胜教程(有挂攻略)是由北京得微信闲来辅助神器免费...
第十分钟辅助(哈灵小程序脚本)... 第十分钟辅助(哈灵小程序脚本)确实是有挂(详细辅助黑科技教程);1、每一步都需要思考,不同水平的挑战...
大家学习交流“凑一桌游戏关春天... 大家学习交流“凑一桌游戏关春天辅助器”一贯真的有挂(辅助挂)详细辅助辅助教程1、全新机制【软件透明挂...
透视有挂!wepoker辅助器... 透视有挂!wepoker辅助器软件下载,随意玩辅助器透视挂,攻略教程(有挂插件);1、下载好随意玩辅...
两分钟辅助!新九九辅助(辅助挂... 自定义新九九辅助系统规律,只需要输入自己想要的开挂功能,一键便可以生成出微扑克专用辅助器,不管你是想...
透视能赢!福建兄弟13水插件,... 1、透视能赢!福建兄弟13水插件,决战卡五星辅助看牌器,扑克教程(有挂软件);详细教程。2、决战卡五...
第5分钟辅助(小程序广东雀神智... 第5分钟辅助(小程序广东雀神智能插件免费)一直是真的有挂(详细辅助玩家教你)1、小程序广东雀神智能插...