gpt4 book ai didi

oracle11g - 无法删除最旧的表分区

转载 作者:行者123 更新时间:2023-12-04 15:05:20 25 4
gpt4 key购买 nike

我在其中一张表中使用了 11g 间隔分区功能。我将它设置为在时间戳字段上创建 1 天分区,并创建了一个作业来删除 3 个月前的数据。当我尝试删除最旧的分区时,出现以下错误:

ORA-14758: Last partition in the range section cannot be dropped



我原以为“最后一个”是指最新的分区而不是最旧的分区。我应该如何解释这个错误?我的分区有问题吗,还是我应该一直保留最旧的分区?

最佳答案

是的,错误消息有点误导,但它指的是最后一个 STATICALLY 创建的分区(在 Oracle 开始自动创建分区之前的原始表 DDL 中。我认为避免这种情况的唯一方法是创建一个人为的“MINVAL”分区你肯定永远不会被使用,然后把真正的分区放在这个上面。

[交换意见后编辑]

我假设这个测试用例重现了你的问题:

CREATE TABLE test 
( t_time DATE
)
PARTITION BY RANGE (t_time)
INTERVAL(NUMTODSINTERVAL(1, 'DAY'))
( PARTITION p0 VALUES LESS THAN (TO_DATE('09-1-2009', 'MM-DD-YYYY')),
PARTITION p1 VALUES LESS THAN (TO_DATE('09-2-2009', 'MM-DD-YYYY')),
PARTITION p2 VALUES LESS THAN (TO_DATE('09-3-2009', 'MM-DD-YYYY')),
PARTITION p3 VALUES LESS THAN (TO_DATE('09-4-2009', 'MM-DD-YYYY'))
);
insert into test values(TO_DATE('08-29-2009', 'MM-DD-YYYY'));
insert into test values(TO_DATE('09-1-2009', 'MM-DD-YYYY'));
insert into test values(TO_DATE('09-3-2009', 'MM-DD-YYYY'));
insert into test values(TO_DATE('09-10-2009', 'MM-DD-YYYY'));

当我这样做时,我可以删除分区 p0、p1 和 p2,但是在尝试删除 p3 时会出现错误,即使除此之外还有系统生成的分区。

我能找到的唯一解决方法是通过以下方式临时重新定义表分区:
alter table test set interval ();

然后删除分区 p3。然后,您可以通过以下方式根据原始规范重新定义分区:
alter table test set INTERVAL(NUMTODSINTERVAL(1, 'DAY'));

关于oracle11g - 无法删除最旧的表分区,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1395379/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com