数据库分片和分区

1.分片Database Sharding

是一种 水平拆分(Horizontal Partitioning,按行拆分) 的方案,用来解决单机数据库在数据量、并发量上的瓶颈问题。(垂直拆分是指按列的字段拆分。)

一句话定义:

把同一张逻辑表的数据,按某种规则拆分,分布存储在多台数据库机器(或多个库/表)上。

  • 对业务来说, 还是"一张表"

  • 对物理存储来说: 实际是"多台机器上的多张表"

    // 逻辑上一张表
    user(id, name, age, ...)

    // 分片后,物理结构可能是:
    db1.user_0 (存 user_id % 2 == 0 的数据)
    db2.user_1 (存 user_id % 2 == 1 的数据)

    //从业务视角查询:
    SELECT * FROM user WHERE id = 123;

    // 底层处理时
    SELECT * FROM db2.user_1 WHERE id = 123;

1.1 缺点

  1. 跨分片查询。
  2. 自增主键不再可用。

2.分区

表分区 是数据库(如 MySQL、PostgreSQL)提供的一种单库内的物理拆分机制

核心点:

  • 对业务是 1 张表

  • 对数据库也是 1 个库

  • 对存储引擎来说是多份数据文件

👉 所有分区都在同一台数据库实例里。按时间分区的例子:

sql 复制代码
CREATE TABLE orders (
    id BIGINT NOT NULL,
    create_time DATE NOT NULL,
    amount INT,
    PRIMARY KEY (id, create_time)
)
PARTITION BY RANGE (TO_DAYS(create_time)) (
    PARTITION p202401 VALUES LESS THAN (TO_DAYS('2024-02-01')),
    PARTITION p202402 VALUES LESS THAN (TO_DAYS('2024-03-01'))
);

已有数据的表新增分区,必须创建时已有分区才行:

sql 复制代码
ALTER TABLE orders
ADD PARTITION (
    PARTITION p202403 VALUES LESS THAN (TO_DAYS('2024-04-01'))
);

3.月表怎么创建

相关推荐
Sst的头号粉丝10 分钟前
轻量级博客搭建
数据库
用户62799471826212 分钟前
南大通用GBase 8c数据库权限管理场景实践
数据库
八月瓜科技12 分钟前
擎策·知海全球专利数据库 专业专利检索赋能 规避无效研发提效创新
大数据·数据库·人工智能·科技·aigc
2401_8331977315 分钟前
更优雅的测试:Pytest框架入门
jvm·数据库·python
倔强的石头_22 分钟前
Oracle 迁移 TCO 深度拆解:从隐性运维成本陷阱到全栈工具链破局
数据库
2501_9249526929 分钟前
Python深度学习入门:TensorFlow 2.0/Keras实战
jvm·数据库·python
2401_8914821731 分钟前
Python多线程与多进程:如何选择?(GIL全局解释器锁详解)
jvm·数据库·python
Predestination王瀞潞32 分钟前
6.3.1 软件->W3C XPath 1.0 标准(W3C Recommendation):XPath(XML Path Language)查询语言
xml·数据库·oracle
2401_8512729932 分钟前
用Python实现自动化的Web测试(Selenium)
jvm·数据库·python
快乐柠檬不快乐38 分钟前
Java连接电科金仓数据库(KingbaseES)实战指南
java·开发语言·数据库