当前位置:网站首页>MySQL的分库分表策略及应用场景
MySQL的分库分表策略及应用场景
2022-06-29 08:17:00 【amateur12】
分库
解决单台数据库的性能问题
水平分库:取模
确定需要将数据平均分配到多少个库中,也就是:库容量
对用户ID进行取模,user_id%库容量,结果为0的在第一个库,结果为1的在第二个库。。。
垂直分库:根据业务拆分
订单数据过多时可给订单单独创建数据库
分表
解决单表海量数据的查询性能问题
水平分表
以行为单位对数据进行拆分
分表之后,所有表的结构都是一样的
解决表数据太多的问题
方法:确定需要将数据平均分配到多少张表中,也就是:表容量
对用户ID进行取模,user_id%表容量,结果为0的在第一张表,结果为1的在第二张表。。。
垂直分表
按列分为多张表,多张表通过主键进行关联,从而组成完整的数据
分表之后,每张表的结构都不相同
解决列太多的问题
同时分库分表
中间变量 = user_id%(库容量*每个库的表容量)
库号 = 取整(中间变量/每个库的表容量)
表号 = 中间变量%每个库的表容量
弊端
原本跨表的事物变成了分布式事物;
由于记录被切分到不同的数据库和不同的数据表中,难以进行多表关联查询,并且查询要指定数据的库号表号。
对系统进行进一步的扩阵容(库号表号变更),将变得非常不方便,需要我们重新进行数据迁移。
多少数据量分表合适
理论500w可分表(分表后比较快)
实际1000w-2000w左右才分表
总之不能超过5000w才分表,5000w是索引极限
补充:如果订单数据需要做出统计,统计每个月销售量之类的信息,可以使用按月分表,否则,不建议,因为可能会造成某个月份数据太多,而某个月份数据很少的情况
边栏推荐
猜你喜欢

城通网盘仿蓝奏网盘源码 附带视频教程

A high-frequency problem, three kinds of model thinking to solve this risk control problem

机器人代码生成器之Robcogen使用教程

802.11--802.11n protocol phy

MQTT第二话 -- emqx高可用集群实现

使用adb命令调试夜神模拟器

VMware vcenter/esxi series vulnerability summary

重磅发布 | 《FISCO BCOS应用落地指南》

闭关修炼(二十五)基础web安全

Huawei equipment is configured with medium-sized network WLAN basic services
随机推荐
Voice processing tool: Sox
Speech synthesis: overview [generation task of unequal length sequence relation modeling]
互斥量互斥锁
开发小技巧-图片资源管理
Sorting out easily confused words in postgraduate entrance examination English 【 flash 】
Differences between x86 and x64
首次触电,原来你是这样的龙蜥社区 | 龙蜥开发者说第8期
[hcie TAC] question 5-2
Is the securities account of qiniu school really safe and reliable?
【无标题】
[domain penetration authorization] cve-2020-1472 Netlogon privilege escalation vulnerability
“国防七校”之一西工大遭境外网络攻击
【最全】PS各个版本下载安装及小试牛刀教程(PhotoShop CS3 ~~ PhotoShop 2022)
(pytorch进阶之路三)encoder self attention mask
操作系统产品密钥查看方法
今年的网络安全“体检”你做了吗?
802.11--802.11n protocol phy
Actual combat memoir starts from webshell to break through the border
P6776-[noi2020] surreal tree
搭建开源物联网平台教程