ALTER SEQUENCE 修改序列解决唯一约束冲突 unique constraint violated

时间:2023-03-09 01:21:02
ALTER SEQUENCE 修改序列解决唯一约束冲突 unique constraint violated

背景

自增序列会遇到也会遇到唯一约束冲突吗?是的,最常见的情况就是数据迁移之后,导致数据最大值超过序列值。

软件开发中不遇到些出乎意料的问题,总感觉不太够劲。

修改序列(ALTER SEQUENCE)

用于修改序列的当前值、最大值、最小值、缓存长度等。我们以Oracle为例,语法如下图

ALTER SEQUENCE 修改序列解决唯一约束冲突 unique constraint violated

ALTER SEQUENCE 修改序列解决唯一约束冲突 unique constraint violated

ALTER SEQUENCE 修改序列解决唯一约束冲突 unique constraint violated

我们要做的是修改序列的当前值,与当前字段的数据最大值做同步。好,我们先来查询一下当前序列当前值

SELECT seqname.CURRVAL FROM dual

  

OR

SELECT last_number
FROM user_sequences
WHERE sequence_name='seqname'

  

然后修改序列值,比如增加100

ALTER SEQUENCE seqname INCREMENT BY 100;

  

最后校验一下序列的nextval,一定要超过目前的数据最大值。

SELECT seqname.NEXTVAL FROM dual

  

参考资料

Oracle ALTER SEQUENCE:https://docs.oracle.com/cd/B19306_01/server.102/b14200/statements_2011.htm