序列到达最大值后如何处理,探讨探讨

我定义了一个字段NJL_SN NUMBER(10,0),再创建序列
CREATE SEQUENCE NJL_SN
NOCYCLE
MAXVALUE 9999999999
START WITH 1000;
然后每插入一条记录,序列NJL_SN增加1;则如果数据增至9999999999时,而该表中的记录不能删除,且我创建的序列也不能循环(NOCYCLE),这时会出现错误ORA-08004: 序列NJL_SN.NEXTVAL exceeds MAXVALUE 无法实例化,请问,这时该如何处置?
当然开始的时候我设置NJL_SN为NUMBER(20,0),创建序列MAXVALUE为99999999999999999999,足够大,按常理是不大可能到达的,但是问题毕竟在此,没有什们不可能的事情,还有,如果序列创建的MAXVALUE创建的足够大,不知道是不是会占有空间,是否会延误数据库的速度等一系列问题?
当然我设置序列循环(Cycle)是可以一直循环下去,但是我们一般把创建的序列字段设置为主键PK的,这就又不允许循环。

不知道大家针对这种情况,是如何处理的?
我的意思是说万一字段值达到最大,而记录又唯一,不能删除,该如何处理,大家都是用什们办法解决的,我想银行里会很容易碰到这种情况的

---------------------------------------------------------------

几点吧:
1、maxvalue设为很大其实也没什么关系的,当然不会点更多空间,因为它是存在数据字典中的一条记录,也没什么影响速度的可能,这个不必担心。
2、我认为你的设计有问题,也就是你对pk的设计有问题 ,你不能单单的用sequence生成的什就做为pk了,生成唯一值的方法很多的,
比如to_char(sysdate,'yyyymmddhh24miss') ¦ &brvbarto_char(sequence1.nextval),这时你可以把这个序列设为cycle了。

---------------------------------------------------------------

哦,不好意思,没有看清。

hrb_qiuyb(大森林) 第二条说得不错。
我想了一下,觉得还是可以检索当前序列种空缺的重用。就是你到达某一个数值后,最后找在某一范围内的当前不存在的数值使用。不过要是你的数据量序列要用number(20),我的估计就行不通,主要速度跟不上。
呵呵,我觉得没那么恐怖吧?
---------------------------------------------------------------

CREATE SEQUENCE USERID INCREMENT BY 1 START WITH 1
MAXVALUE 1.0E28 MINVALUE 1 CYCLE
NOCACHE NOORDER;

select to_char(sysdate,'yyyymmdd') ¦ ¦ lpad(USERID.nextval,4,'0') into :new.yyghno from dual;

一般这样设计,允许它循环,用日期限定它唯一

Published At
Categories with 数据库类
Tagged with
comments powered by Disqus