分区表 RANGE / LIST 分区在时间序列表上的创建模板

发布时间 - 2026-01-29 00:00:00    点击率:
时间序列数据优先选RANGE分区,因其天然适配时间连续性,支持按月/天自动切分且可覆盖未来时间点;LIST需显式枚举值,维护成本高、不适用时间维度。

为什么时间序列数据优先选 RANGE 分区而不是 LIST

RANGE 分区天然适配时间序列的连续性特征,比如按月、按天切分 created_at 字段;而 LIST 分区要求显式枚举每个分区值(如 '2025-01', '2

025-02'),无法自动覆盖未来时间点,维护成本高。MySQL 8.0+ 和 PostgreSQL 的分区机制都对 RANGE 时间分区有原生优化,LIST 在时间维度上基本不适用。

MySQL 中创建 RANGE 分区的最小可用模板

注意:必须使用 DATEDATETIMETIMESTAMP 类型字段,且该字段需为分区键(不能是表达式);VALUES LESS THAN 必须严格递增,且最后一个分区建议用 MAXVALUE 拦截溢出数据。

CREATE TABLE logs (
  id BIGINT NOT NULL,
  created_at DATETIME NOT NULL,
  content TEXT
) PARTITION BY RANGE (TO_DAYS(created_at)) (
  PARTITION p202501 VALUES LESS THAN (TO_DAYS('2025-02-01')),
  PARTITION p202502 VALUES LESS THAN (TO_DAYS('2025-03-01')),
  PARTITION p202503 VALUES LESS THAN (TO_DAYS('2025-04-01')),
  PARTITION p_future VALUES LESS THAN MAXVALUE
);
  • TO_DAYS() 是 MySQL 常用转换函数,避免直接用 DATETIME 值导致语法错误
  • 不要用 YEAR(created_at)MONTH(created_at),它们不单调,会导致分区重叠或空洞
  • 新增分区需用 ALTER TABLE ... ADD PARTITION,不能靠插入自动触发

PostgreSQL 中按时间 RANGE 分区的声明式写法

PostgreSQL 10+ 支持声明式分区,语法更直观,但必须先建主表并指定 PARTITION BY RANGE,再逐个创建子分区;子分区的 FOR VALUES FROMTO 是左闭右开区间,且不能有间隙或重叠。

CREATE TABLE logs (
  id BIGSERIAL,
  created_at TIMESTAMP WITHOUT TIME ZONE NOT NULL,
  content TEXT
) PARTITION BY RANGE (created_at);

CREATE TABLE logs_202501 PARTITION OF logs
  FOR VALUES FROM ('2025-01-01') TO ('2025-02-01');

CREATE TABLE logs_202502 PARTITION OF logs
  FOR VALUES FROM ('2025-02-01') TO ('2025-03-01');

CREATE TABLE logs_default PARTITION OF logs
  DEFAULT;
  • 子分区名无强制规范,但建议含时间标识,便于运维识别
  • DEFAULT 分区可兜底未匹配的数据,但会削弱查询剪枝效果,慎用
  • 若需定期添加新分区,得配合脚本调用 CREATE TABLE ... PARTITION OF,PG 不支持自动滚动

容易被忽略的三个硬约束

无论 MySQL 还是 PostgreSQL,以下限制一旦违反,分区就失效或报错:

  • 分区键字段不能为 NULL —— 时间字段缺失会导致插入失败或落入 DEFAULT 分区,破坏时序局部性
  • 查询条件中若未包含分区键(如只查 id = 123),优化器无法剪枝,全分区扫描性能反降
  • MySQL 中 TO_DAYS()NULL 返回 NULL,而 NULL 永远不满足任何 LESS THAN 条件,这类记录会被丢弃(不是存入 MAXVALUE 分区)

时间分区不是设完就一劳永逸的事,关键在持续管理分区边界和确保写入数据的时间字段始终有效。


# mysql  # 为什么  # igs  # sql  # less  # NULL  # for  # date  # timestamp  # default  # table  # postgresql  # 切分  # 不适用  # 按月  # 未来  # 这类  # 不支持  # 报错  # 能为  # 都对  # 因其 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Win11怎么查看显卡温度 Win11任务管理器查看GPU温度【技巧】  详解jQuery中的事件  Laravel如何实现全文搜索功能?(Scout和Algolia示例)  香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化  Laravel中间件如何使用_Laravel自定义中间件实现权限控制  如何快速搭建FTP站点实现文件共享?  利用vue写todolist单页应用  EditPlus中的正则表达式实战(5)  laravel怎么配置和使用PHP-FPM来优化性能_laravel PHP-FPM配置与性能优化方法  Laravel安装步骤详细教程_Laravel环境搭建指南  Laravel怎么使用Markdown渲染文档_Laravel将Markdown内容转HTML页面展示【实战】  Python数据仓库与ETL构建实战_Airflow调度流程详解  微信小程序 闭包写法详细介绍  宙斯浏览器怎么屏蔽图片浏览 节省手机流量使用设置方法  移动端脚本框架Hammer.js  Laravel怎么使用Collection集合方法_Laravel数组操作高级函数pluck与map【手册】  Mybatis 中的insertOrUpdate操作  laravel怎么配置Redis作为缓存驱动_laravel Redis缓存配置教程  JS经典正则表达式笔试题汇总  Laravel如何集成微信支付SDK_Laravel使用yansongda-pay实现扫码支付【实战】  昵图网官网入口 昵图网素材平台官方入口  如何在局域网内绑定自建网站域名?  Laravel怎么进行数据库事务处理_Laravel DB Facade事务操作确保数据一致性  Laravel如何编写单元测试和功能测试?(PHPUnit示例)  VIVO手机上del键无效OnKeyListener不响应的原因及解决方法  免费网站制作appp,免费制作app哪个平台好?  Laravel如何使用.env文件管理环境变量?(最佳实践)  JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)  如何挑选优质建站一级代理提升网站排名?  成都网站制作公司哪家好,四川省职工服务网是做什么用?  Laravel Eloquent模型如何创建_Laravel ORM基础之Model创建与使用教程  网站页面设计需要考虑到这些问题  Laravel Livewire是什么_使用Laravel Livewire构建动态前端界面  在Oracle关闭情况下如何修改spfile的参数  如何在建站之星绑定自定义域名?  javascript中的数组方法有哪些_如何利用数组方法简化数据处理  详解Nginx + Tomcat 反向代理 如何在高效的在一台服务器部署多个站点  Java Adapter 适配器模式(类适配器,对象适配器)优缺点对比  Laravel的.env文件有什么用_Laravel环境变量配置与管理详解  QQ浏览器网页版登录入口 个人中心在线进入  智能起名网站制作软件有哪些,制作logo的软件?  JavaScript实现Fly Bird小游戏  如何正确选择百度移动适配建站域名?  如何有效防御Web建站篡改攻击?  Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制  如何快速选择适合个人网站的云服务器配置?  Laravel如何自定义错误页面(404, 500)?(代码示例)  如何在宝塔面板创建新站点?  Laravel项目如何进行性能优化_Laravel应用性能分析与优化技巧大全  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?