sql >> Base de Datos >  >> RDS >> Oracle

¿Cómo restablezco una secuencia en Oracle?

Aquí hay un buen procedimiento para restablecer cualquier secuencia a 0 del gurú de Oracle Tom Kyte. Gran discusión sobre los pros y los contras en los enlaces a continuación también.

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

Desde esta página:SQL dinámico para restablecer el valor de secuencia
Otra buena discusión también está aquí:¿Cómo restablecer secuencias?