Ето една добра процедура за нулиране на всяка последователност на 0 от гуруто на Oracle Том Кайт. Страхотна дискусия за плюсовете и минусите също в връзките по-долу.
[email protected]>
create or replace
procedure reset_seq( p_seq_name in varchar2 )
is
l_val number;
begin
execute immediate
'select ' || p_seq_name || '.nextval from dual' INTO l_val;
execute immediate
'alter sequence ' || p_seq_name || ' increment by -' || l_val ||
' minvalue 0';
execute immediate
'select ' || p_seq_name || '.nextval from dual' INTO l_val;
execute immediate
'alter sequence ' || p_seq_name || ' increment by 1 minvalue 0';
end;
/
От тази страница:Динамичен SQL за нулиране на стойността на последователността
Тук е и друга добра дискусия:Как да нулирате последователности?