数据库分片和分区

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.月表怎么创建

相关推荐
Omics Pro2 分钟前
首个!外源天然产物综合性代谢图谱
数据库·人工智能·算法·机器学习·r语言
JAVA面经实录9171 小时前
Hibernate面试题库
数据库·oracle·hibernate
迷枫7122 小时前
DM8 目录结构与常用排查入口梳理
服务器·数据库
Mr.Daozhi3 小时前
RAG 进阶实战:跑通 Demo 后我连续翻了 6 次车,逐一修复才真正可用(含 Gradio Web 版)
前端·数据库·langchain·大模型·gradio·rag·科研工具
小程故事多_803 小时前
Claude Code自定义workflow skills用法
数据库·人工智能·智能体
大鹏说大话3 小时前
SQL 排序与分组实战:解决“分组后取最新数据“
android·java·数据库
夏贰四3 小时前
数据建模工具如何筑牢数据根基?数据建模工具怎样落实标准体系?
数据库·数学建模·数据建模工具
程序猿阿伟5 小时前
《一套完整方法论:搞定图形应用的Docker镜像优化》
数据库·docker·容器
二等饼干~za8986685 小时前
geo优化源码开发搭建技术分享
大数据·网络·数据库·人工智能·音视频
数据库小学妹5 小时前
HTAP混合负载架构:如何用一个数据库同时搞定交易和分析
数据库·经验分享·架构·dba