当前位置: 首页 > news >正文

数据库分片和分区

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 个库

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

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

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')) );

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

ALTER TABLE orders ADD PARTITION ( PARTITION p202403 VALUES LESS THAN (TO_DAYS('2024-04-01')) );

3.月表怎么创建

http://www.jsqmd.com/news/212189/

相关文章:

  • 超绝好用清理软件工具,(附下载方式)超多好用功能
  • 何为Transformer 架构?
  • HiBit Uninstaller全攻略:轻量无广,彻底告别软件残留(附下载方式)
  • 电阻的基础知识
  • jvm性能调优
  • 【光子AI】FastAPI 极简权威指南 (The Ultimate Minimalist Guide)
  • 【光子AI】FastAPI 极简教程(从 0 到 生产级)
  • mysql一条sql语句是如何运行的
  • 什么是勒索软件即服务(RaaS)
  • MySQL 8.0在windows环境安装及配置
  • MySQL 导出数据
  • 【计算机毕业设计案例】基于深度学习CNN的水果识别
  • 什么是立体射频调优
  • 什么是零漫游分布式AP
  • Thinkphp和Laravel框架的西安工商学院学生请假管理系统_s4hrg6g5
  • 什么是零日攻击
  • MySQL 实验1:Windows 环境下 MySQL5.5 安装与配置
  • 全网最全9个AI论文平台,专科生毕业论文写作必备!
  • Vue 3 中,unmounted 生命周期钩子会在组件实例被销毁并从 DOM 中移除后调用
  • MacOs安装Redis并设置为开机、后台启动
  • 深度学习毕设项目推荐-基于python深度学习的土豆疾病识别
  • Linux系统下安装配置Nginx(保姆级教程)
  • MySQL —— 配置文件
  • iPerf新手攻略:快速搭建网络测试环境!
  • 2026 外贸独立站如何利用 GSC 与 Ahrefs 追踪 AI Visibility可见性
  • vulnhub靶场实战系列-1.靶场实战平台介绍|课程笔记|网络安全|
  • Linux安装Redis以及Redis三种启动方式
  • MySQL 字符串日期格式转换
  • MCU+AT向OpenCPU转型:技术变革的必然性深度解析(全篇完结)
  • mysql WITH的多种用法与示例