分区表 RANGE / LIST 分区在时间序列表上的创建模板
发布时间 - 2026-01-29 00:00:00 点击率:次时间序列数据优先选RANGE分区,因其天然适配时间连续性,支持按月/天自动切分且可覆盖未来时间点;LIST需显式枚举值,维护成本高、不适用时间维度。
为什么时间序列数据优先选 RANGE 分区而不是 LIST
RANGE 分区天然适配时间序列的连续性特征,比如按月、按天切分 created_at 字段;而 LIST 分区要求显式枚举每个分区值(如 '2025-01', '2),无法自动覆盖未来时间点,维护成本高。MySQL 8.0+ 和 PostgreSQL 的分区机制都对 RANGE 时间分区有原生优化,LIST 在时间维度上基本不适用。
MySQL 中创建 RANGE 分区的最小可用模板
注意:必须使用 DATE、DATETIME 或 TIMESTAMP 类型字段,且该字段需为分区键(不能是表达式);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 FROM 和 TO 是左闭右开区间,且不能有间隙或重叠。
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应用性能分析与优化技巧大全
邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?

