oracle 备份删除分区 -> 交换分区

前言

oracle 备份删除分区_oracle range分区根据值删除分区-CSDN博客

之前以数据崩expdp/impdp方式备份和drop partition删除分区对需求进行了实践,本篇使用交换分区EXHCANGE PARTITION方式备份删除分区。

流程:创建与原分区表tableName结构和索引结构相同的临时表;交换分区并更新全局索引;验证全局索引状态是否生效VALID;删除原分区表空分区(交换分区的方式是修改元数据,可以通过分区查下方式查到空的分区表,这里要删掉);删除临时表,如果作为备份可以加备份分区的标识(例如:按月份分区的,本次交换分区是2024年1月份。tableName_202401);再次验证全局索引是否生效VALID。

优点:由于交换分区操作主要是修改元数据,所以执行速度较快,对系统影响较小。在交换分区时同时使用UPDATE GLOBAL INDEXES选项可以更新索引(更新索引也可以分开执行),虽然也需要扫描相关数据块,但相比于重建索引,性能开销要小很多。因为它只是对受影响的部分索引项进行更新,而不是重建构件整个索引,不会影响原分区表其它分区查询。交换分区后,原分区分区表会有一个空分区,此时再DROP分区,由于没有数据删除分区对原分区表索引没影响。

以下是按照前言描述,在oracle11g版本中使用 Oracle SQL 实现创建临时表、交换分区、更新全局索引、验证索引状态、删除空分区和临时表等操作的详细实例:

1. 创建分区表及全局索引

首先,我们创建一个示例分区表 tableName 并为其添加全局索引:

-- 创建分区表
CREATE TABLE tableName (
    id
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值