序列对象有三个重要的属性:起始值、增量和最大值。起始值是序列生成的第一个值,增量是序列每次生成的值的增量,最大值是序列可以生成的最大值。这些属性可以在创建序列时设置,也可以在创建后随时更改。
要修改Oracle序列的当前值,可以使用ALTER SEQUENCE语句。该语句需要指定序列的名称和新的当前值。例如,要将一个名为my_sequence的序列的当前值修改为100,可以使用以下语句:
|
1 |
Alter Sequence my_sequence START WITH 100; |
注意,该语句只修改序列的当前值,不影响序列的起始值、增量或最大值。
以下是一些常见的选项:
|
1 2 3 4 5 6 7 8 9 10 11 |
2.1、修改序列起始值 Alter Sequence my_sequence START WITH 1;
2.2、修改序列的增量 Alter Sequence my_sequence Increment By 2;
2.3、修改序列最大值 Alter Sequence my_sequence Maxvalue 1000;
2.4、启动序列的循环 Alter Sequence my_sequence Cycle; |
在使用以上语句时,请注意以下几点:
1、ALTER SEQUENCE语句需要在管理员权限下执行。
2、修改序列对象的属性可能会影响其他依赖于该序列的数据库对象,比如触发器、约束等。在做出修改时,请确认是否需要修改其他对象。
3、修改序列对象的属性可能导致序列生成的值与已分配的值重复。请仔细考虑修改的影响,并进行必要的备份和测试。
1.查询序列的下一个值:SELECT SEQ_NAME.NEXTVAL FROM dual;
2.如果想修改序列的下个值:经常遇到ID已经存在的情况, 这时候, 你可以修改步长, 让他下一次执行(第3步)就可以达到最大值(执行完后记得改回来)
alter sequence SEQ_NAME increment BY X; ----X为正数负数都可以
3.查询序列的下一个值:SELECT SEQ_NAME.NEXTVAL FROM dual; --查看是否修改成功
4.重新将序列的值的增长值设为1alter sequence SEQ_NAME increment BY 1;
##修改方式
SQL:
|
1 2 3 |
alter sequence seq_test increment by n; --n为做自增能够达到预想的值 select seq_test.nextval from dual; – 做一次nextval也能得到预想的值 alter sequence seq_test increment by 1; – 再将序列的自增值修改回去 |

先查询下一次的值,然后在做修改。框住的为自己的流水号名称。