0

0

如何收缩分区表的高水位线_ALTER TABLE SHRINK SPACE对单个分区的支持

P粉602998670

P粉602998670

发布时间:2026-03-16 09:26:04

|

789人浏览过

|

来源于php中文网

原创

不能,ALTER TABLE ... SHRINK SPACE 不支持单个分区;需用 ALTER TABLE ... SHRINK SPACE PARTITION,且仅限 11gR2+ 的 RANGE/LIST/INTERVAL 堆表,并要求启用行移动。

Oracle 分区表单个分区能用 ALTER TABLE ... SHRINK SPACE 吗?

不能直接对单个分区执行 alter table ... shrink space。这个语句只作用于整个表(或 iot),不支持 partition 关键字。想收缩某个分区,必须换用分区级命令。

ALTER TABLE ... SHRINK SPACE PARTITION 的真实行为

Oracle 11gR2 起才支持该语法,但仅限于 LISTRANGEINTERVAL 分区的堆表(非索引组织表),且要求表启用行移动(ENABLE ROW MOVEMENT)。它实际做三件事:整理碎片、回收空间、更新高水位线(HWM)——但不会自动释放到表空间,需后续 ALTER TABLESPACE ... COALESCE 或手动 ALTER DATABASE DATAFILE ... RESIZE

  • 必须先执行 ALTER TABLE t ENABLE ROW MOVEMENT,否则报错 ORA-10636: row movement is not enabled
  • 分区名必须显式写出,不支持通配符或子查询
  • 若分区上有本地索引(LOCAL),收缩后索引会自动维护;全局索引(GLOBAL)则需重建或指定 UPDATE GLOBAL INDEXES
  • 执行期间该分区被加 SS(sub-share)锁,DML 不阻塞,但 DDL 会被挂起

常见错误:ORA-10631 和收缩失败的典型原因

ORA-10631: SHRINK clause should not be specified for this object 是最常遇到的报错,根本原因是对象类型不支持——比如试图对索引组织表(IOT)、外部表、物化视图日志表、或者未启用行移动的分区表执行收缩。

  • 检查是否是 IOT:SELECT iot_type FROM user_tables WHERE table_name = 'T',返回 IOTIOT_OVERFLOW 就不支持
  • 确认行移动已开启:SELECT row_movement FROM user_tables WHERE table_name = 'T',结果必须是 ENABLED
  • 分区表若含 LOB 列,需额外验证 LOB 段是否也启用了 ENABLE STORAGE IN ROW,否则可能静默跳过 LOB 数据收缩
  • 使用 DBMS_SPACE.SPACE_USAGE 查 HWM 前后变化,别只看 BYTES 字段——UNFORMATTED_BLOCKS 才反映真实可回收量

替代方案:当 SHRINK SPACE PARTITION 不可用时

如果环境是 10g、或表结构受限(如含 LONG、嵌套表)、或需要更精细控制空间回收节奏,就只能绕道。核心思路是“导出 → 截断 → 重载”,但必须避开全表锁和长事务风险。

Tweeze
Tweeze

Tweeze.app是一个AI驱动的个性化新闻简报服务,定位为个人互联网AI阅读助手

下载
  • CREATE TABLE t_new AS SELECT * FROM t PARTITION (p1) WHERE 1=0 快速建空分区结构
  • 交换分区:ALTER TABLE t EXCHANGE PARTITION p1 WITH TABLE t_new(要求约束、索引等完全匹配)
  • 再对 t_new 执行 TRUNCATE TABLE t_new REUSE STORAGE,此时原分区数据已清空,空间立即释放
  • 若需保留数据,改用 INSERT /*+ APPEND */ INTO t_new SELECT /*+ FULL(t) */ * FROM t PARTITION (p1) + 交换,但注意归档模式下会产生大量 redo

真正麻烦的不是语法,而是收缩前后统计信息失效、本地索引状态异常、以及业务高峰期锁等待堆积——这些点不提前压测,上线就卡住。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

448

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

606

2023.08.10

append用法
append用法

append是一个常用的命令行工具,用于将一个文件的内容追加到另一个文件的末尾。想了解更多append用法相关内容,可以阅读本专题下面的文章。

349

2023.10.25

python中append的用法
python中append的用法

在Python中,append()是列表对象的一个方法,用于向列表末尾添加一个元素。想了解更多append的更多内容,可以阅读本专题下面的文章。

1080

2023.11.14

python中append的含义
python中append的含义

本专题整合了python中append的相关内容,阅读专题下面的文章了解更多详细内容。

187

2025.09.12

oracle清空表数据
oracle清空表数据

当表中的数据不需要时,则应该删除该数据并释放所占用的空间。本专题为大家提供oracle清空表数据的相关文章,帮助大家解决该问题。

271

2023.08.16

Oracle中declare的使用
Oracle中declare的使用

Oracle DECLARE语句是PL/SQL编程语言中用于声明变量、常量、游标或异常的关键字。它的主要作用是在程序中定义这些对象,以便在后续的代码中使用。DECLARE语句的语法简单明了,可以根据需要声明多个对象。通过使用这些声明的对象,可以进行各种操作,如计算、查询数据库、处理异常等 。

221

2023.09.15

oracle怎么分页
oracle怎么分页

实现分页的步骤:1、使用ROWNUM进行分页查询;2、在执行查询之前进行设置分页参数;3、使用"COUNT(*)"函数来获取总行数,并使用"CEIL"函数来向上取整计算总页数;4、在外部查询中使用"WHERE"子句来筛选出特定的行号范围,以实现分页查询。想了解更多oracle怎么分页的文章,可以来阅读本专题先的文章。

248

2023.09.18

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

69

2026.03.13

热门下载

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

精品课程

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

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