清理Oracle序列

时间:2011-02-09 17:30:30

标签: oracle sequence reset

我与SQL Server进行了广泛的合作,但对Oracle的经验却很少。我已经被赋予了“清理”Oracle数据库中的序列的任务,并且不确定如何安全地进行此操作。

我需要确定表中实际的最大值(比如ID = 105)。然后查看该ID的下一个序列是什么。如果它是106,那么一切都会好的。如果它是110,那么我需要将它重置回106.

我可以安全地删除序列然后重新创建它还是会破坏现有的主键?我猜这不会是一个问题,但在我抬起别人的系统之前,我想问一下。

这是我要使用的命令

Drop Sequence blah.foo_seq
Create Sequence blah.foo_seq Start WIth 106 Min 1 Max 2147483647 yada yada

1 个答案:

答案 0 :(得分:11)

我一般都对“清理”Oracle序列的需要持谨慎态度。由于Oracle序列不能用于生成无间隙值,如果110会导致应用程序出现问题,则需要解决更大的问题。

删除序列对主键没有影响。但它确实使引用序列的任何对象无效并删除任何权限授予。您可以在重新创建序列后重新编译代码,这是删除可能存在问题的权限。

避免需要处理丢失的权限的另一种方法是更改​​INCREMENT BY参数以减少序列值,即

ALTER SEQUENCE foo_seq
  INCREMENT BY -4;

SELECT foo_seq.nextval
  FROM dual;

ALTER SEQUENCE foo_seq
  INCREMENT BY 1;