程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> 其他數據庫知識 >> MSSQL >> oracle 重置序列從指定命字開端的辦法詳解

oracle 重置序列從指定命字開端的辦法詳解

編輯:MSSQL

oracle 重置序列從指定命字開端的辦法詳解。本站提示廣大學習愛好者:(oracle 重置序列從指定命字開端的辦法詳解)文章只能為提供參考,不一定能成為您想要的結果。以下是oracle 重置序列從指定命字開端的辦法詳解正文


重置oracle序列從指定命字開端

declare
n number(10);
v_startnum number(10):=10000001;--從若干開端
v_step number(10):=1;--步進
tsql varchar2(200);
v_seqname varchar2(200):='MIP_JF_SEQUENCE';--序列名
begin
execute immediate 'select '||v_seqname||'.nextval from dual' into n;
n:=v_startnum-n-v_step;--從10000001開端
tsql:='alter sequence '||v_seqname||' increment by '|| n;
execute immediate tsql;
execute immediate 'select '||v_seqname||'.nextval from dual' into n;
tsql:='alter sequence '||v_seqname||' increment by '||v_step;
execute immediate tsql;
end;
 
欠亨過刪除重建方法 重置序列值得簡略方法。 普通來說,序列在現實開辟進程中是常常用到的一種對象,經由過程它來生成主鍵長短常便利的,然則有些時刻我們須要將其從新置零,平日采取的方法就是刪除後從新創立。
上面我們來看一下別的一種方法:

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;
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>

如許可以經由過程隨時挪用此進程,來到達序列重置的目標。
此存儲進程寫的比擬倉皇,還可以進一步完美,在此就不再進一步講述
Oracle重置序列(不刪除重建方法)
Oracle中普通將自增sequence重置為初始1時,都是刪除再重建,這類方法有許多弊病,依附它的函數和存儲進程將掉效,須要從新編譯。
不外還有種奇妙的方法,不消刪除,應用步長參數,先查出sequence的nextval,記住,把遞增改成負的這個值(反過去走),然後再改回來。
假定須要修正的序列名:seq_name
1、select seq_name.nextval from dual; //假定獲得成果5656
2、alter sequence seq_name increment by -5655; //留意是-(n-1)
3、select seq_name.nextval from dual;//再查一遍,走一下,重置為1了
4、alter sequence seq_name increment by 1;//復原
可以寫個存儲進程,以下是完全的存儲進程,然後挪用傳參便可:

create or replace procedure seq_reset(v_seqname varchar2) as n number(10);
tsql varchar2(100);
begin
execute immediate 'select '||v_seqname||'.nextval from dual' into n;
n:=-(n-1);
tsql:='alter sequence '||v_seqname||' increment by '|| n;
execute immediate tsql;
execute immediate 'select '||v_seqname||'.nextval from dual' into n;
tsql:='alter sequence '||v_seqname||' increment by 1';
execute immediate tsql;
end seq_reset;
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved