0

0

PostgreSQL declarative partitioning 的默认分区与 attach 操作

舞夢輝影

舞夢輝影

发布时间:2026-02-05 17:31:15

|

939人浏览过

|

来源于php中文网

原创

PostgreSQL默认分区无法被ATTACH,只能通过CREATE TABLE ... PARTITION OF ... DEFAULT一次性定义;其本质是约束匹配终点而非可挂载容器,替换需drop+recreate且不支持原子操作。

postgresql declarative partitioning 的默认分区与 attach 操作

默认分区无法直接 attach 分区表

PostgreSQL 的 DEFAULT 分区是兜底容器,它不参与范围/列表约束的显式匹配,因此不能像普通分区那样被 ATTACH PARTITION。一旦你执行 ALTER TABLE ... ATTACH PARTITION ... DEFAULT,会立刻报错:ERROR: cannot attach a partition to a default partition

常见误操作场景:想把一个已有数据的表“转成”默认分区,或试图用 ATTACH 把历史归档表塞进默认分区里 —— 这在语义上不成立,因为 DEFAULT 分区本身就是一个逻辑终点,不是可扩展的挂载点。

  • DEFAULT 分区只能通过 CREATE TABLE ... PARTITION OF ... DEFAULT 一次性定义
  • 已存在的独立表无法通过 ATTACH 变成默认分区;必须先清空或重定向数据,再重建为 DEFAULT 分区
  • 若需动态扩展默认行为(比如按时间归档+兜底),应考虑用触发器或应用层路由,而非依赖 DEFAULT 分区承载新逻辑

attach 操作前必须满足约束兼容性

即使目标不是 DEFAULT 分区,ATTACH PARTITION 也会严格校验被挂载表的约束是否与父表分区键完全匹配。典型失败原因不是语法错,而是隐含的约束冲突。

例如父表按 LIST (status) 分区,而你要 attach 的表虽然有 status 字段,但缺少 CHECK (status IN ('active', 'inactive')),或者约束名重复、表达式写法不一致(如用 status = 'active' 而非 status IN ('active')),都会导致 ERROR: partition constraint is violated by some row 或更隐蔽的 ERROR: no partition of relation "xxx" found for row

  • \d+ parent_table 查看父表各分区的约束定义,逐字比对
  • 被 attach 表必须是空的,或提前运行 ANALYZE 确保统计信息准确,否则约束检查可能误判
  • 若表含继承关系或触发器,需先 DETACH 或禁用,否则 attach 会拒绝

默认分区影响查询计划与数据分布

PostgreSQL 查询优化器会把 DEFAULT 分区当作“最后尝试”的分支,这在多条件查询中容易引发意料外的执行路径。比如父表按 RANGE (created_at) 分区,并设了一个 DEFAULT 分区收容未来日期或 NULL 值;当查询条件含 WHERE created_at > '2030-01-01',优化器可能跳过所有范围分区,直接扫描 DEFAULT 分区 —— 即使该分区实际为空,也可能拖慢计划生成或引入 seq scan。

  • 默认分区的数据不会自动“溢出”到其他分区;插入时只按约束判断,不回退重试
  • 若业务上能明确划分边界(如用 MAXVALUE 替代 DEFAULT),优先不用 DEFAULT,避免优化器路径模糊
  • 监控 pg_stat_all_tables 中默认分区的 n_tup_insn_tup_hot_upd,异常增长往往意味着上游写入逻辑未对齐分区策略

替换默认分区需 drop + recreate,无法 in-place 更新

没有 ALTER TABLE ... REPLACE DEFAULT PARTITION 这种语法。如果需要变更默认分区的结构(比如加字段、改类型、换存储参数),唯一安全方式是:新建一个兼容约束的新表,把原 DEFAULT 分区数据搬过去,然后 DETACH 旧分区并 DROP,最后 CREATE TABLE ... PARTITION OF ... DEFAULT 挂上新表。

这个过程不可原子化,且期间默认分区处于缺失状态 —— 所有本该落入其中的 INSERT 将报错 no partition of relation "xxx" found for row。生产环境务必安排维护窗口,并提前在应用层做降级处理(如暂存消息、重试队列)。

  • 搬数据时用 INSERT INTO new_default SELECT * FROM old_default,不要省略字段列表,防止顺序错位
  • 新表的 CONSTRAINT 必须显式声明为 NOT VALID 再 attach,否则全表扫描验证会阻塞操作
  • 若原默认分区很大,考虑分批迁移 + 触发器拦截写入,而不是锁表等待

默认分区不是“灵活容器”,而是带硬约束的终点;attach 不是文件链接,而是约束契约的现场验签。这两点不厘清,后续的分区膨胀、查询抖动、维护中断都只是时间问题。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

833

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

330

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

351

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1406

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

365

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

983

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

581

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

428

2024.04.29

java连接字符串方法汇总
java连接字符串方法汇总

本专题整合了java连接字符串教程合集,阅读专题下面的文章了解更多详细操作。

4

2026.02.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号