oracle序列重置6,用存储过程重置序列

用存储过程重置序列

SQL> create sequence seq_1 increment by 1 start with 1 maxvalue 999999999;

序列已创建。

SQL> create or replace procedure seq_reset(v_seqname varchar2) as

2 n number(10);

3 tsql varchar2(100);

4 begin

5 execute immediate 'select '||v_seqname||'.nextval from dual' into n;

6 n:=-(n-1);

7 tsql:='alter sequence '||v_seqname||' increment by '|| n;--让序列一次递增-N,实现归0

8 execute immediate tsql;

9 execute immediate 'select '||v_seqname||'.nextval from dual' into n;

10 tsql:='alter sequence '||v_seqname||' increment by 1';

11 execute immediate tsql;

12 end seq_reset;

13 /

过程已创建。

SQL> select seq_1.nextval from dual;

NEXTVAL

---------

2

SQL> /

NEXTVAL

---------

3

SQL> /

NEXTVAL

---------

4

SQL> /

NEXTVAL

---------

5

SQL> exec seq_reset('seq_1');

PL/SQL 过程已成功完成。

SQL> select seq_1.currval from dual;

CURRVAL

---------

1

SQL>

这样可以通过随时调用此过程,来达到序列重置的目的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值