概述
什么是分库分表
- 数据数量是不可控的,随着时间和业务发展,造成表里面数据越来越多,如果再去对数据库表CURD操作时,就会有性能问题。
解决方案
为了解决由于数据量过大而造成数据库性能降低问题,主要有下面两种方案。
- 方案1:从硬件上提高性能,比如CPU,磁盘。
- 方案2:分库分表。
垂直拆分
垂直分表
操作数据库中某张表,把这张表中一部分字段数据存到一张新表里面,再把这张表另一部分字段数据存到另外一张表中。
垂直分库
把单一数据库按照业务进行划分,专库专表。
水平拆分
水平分库
水平分表
分库分表应用和问题
应用
- 在数据库设计的时候考虑垂直分库和垂直分表。
- 随着数据库数据量增加,不要马上考虑水平切分,首先考虑缓存处理,读写分离,使用索引等方式,如果这些方式不能根本解决问题了,再考虑做水平分库和水平分表。
分库分表问题
- 跨节点连接查询问题(分页、排序等)。
- 多数据源管理问题。
总结
垂直拆分,拆分出来的数据结构是不同的。
水平拆分,拆分出来的数据结构相同。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/100041.html