Utilizamos cookies propias y de terceros. [Más información sobre las cookies].
Política de cookies
Proyecto AjpdSoft

· Inicio
· Buscar
· Contactar
· Cookies
· Descargas
· Foros
· Historia
· Nosotros
· Temas
· Top 10
· Trucos
· Tutoriales
· Wiki
Proyecto AjpdSoft: Foros

AjpdSoft :: Ver tema - Resetear/Reiniciar secuencia de Oracle
Foros de discusión Buscar Perfil FAQ Iniciar sesión
Information Resetear/Reiniciar secuencia de Oracle

Publicar nuevo tema Responder al tema
Foros de discusión » Oracle Database, motor de base de datos profesional   
Ver tema anterior :: Ver tema siguiente
AutorMensaje
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: Resetear/Reiniciar secuencia de Oracle Responder citando

¿Cómo puedo reiniciar el valor actual de una secuencia de Oracle? si el contador va por 1500 y quiero ponerlo a 10, por ejemplo ¿cómo lo hago?
MensajePublicado:
Jue Dic 21, 2006 1:08 pm
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Resetear/Reiniciar secuencia de Oracle Responder citando



Anuncios



varios escribió:
¿Cómo puedo reiniciar el valor actual de una secuencia de Oracle? si el contador va por 1500 y quiero ponerlo a 10, por ejemplo ¿cómo lo hago?


La forma más sencilla es eliminarla y volver a crearla:

* Para eliminarla:

Código:
DROP NOMBRE_SECUENCIA


* Para crearla:

Código:
CREATE SEQUENCE NOMBRE_SECUENCIA
INCREMENT BY 1
START WITH 10
MensajePublicado:
Jue Dic 21, 2006 1:24 pm
Top of PageVer perfil de usuario
Villano
Usuario


Registrado: Jun 04, 2007
Mensajes: 1

Asunto: Responder citando

Puedes usar el siguiente procedimiento almacenado para reiniciar tu secuencia, le mandas como parámetros de entrada el nombre de la secuencia y el número al cual la quiere resetear:

create or replace PROCEDURE reset_sequence (
seq_name IN VARCHAR2, startvalue IN PLS_INTEGER) AS

cval INTEGER;
inc_by VARCHAR2(25);

BEGIN
EXECUTE IMMEDIATE 'ALTER SEQUENCE ' ||seq_name||' MINVALUE 0';

EXECUTE IMMEDIATE 'SELECT ' ||seq_name ||'.NEXTVAL FROM dual'
INTO cval;

cval := cval - startvalue + 1;
IF cval < 0 THEN
inc_by := ' INCREMENT BY ';
cval:= ABS(cval);
ELSE
inc_by := ' INCREMENT BY -';
END IF;

EXECUTE IMMEDIATE 'ALTER SEQUENCE ' || seq_name || inc_by ||
cval;

EXECUTE IMMEDIATE 'SELECT ' ||seq_name ||'.NEXTVAL FROM dual'
INTO cval;

EXECUTE IMMEDIATE 'ALTER SEQ
MensajePublicado:
Lun Jun 04, 2007 2:33 pm
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Responder citando

Aquí tienes un artículo sobre las secuencias en Oracle:

http://www.ajpdsoft.com/modules.php?name=News&file=article&sid=181
MensajePublicado:
Dom Sep 06, 2009 6:03 pm
Top of PageVer perfil de usuario
Mostrar mensajes de anteriores:   
Todas las horas son GMT - 1 Horas
Publicar nuevo tema Responder al tema
Foros de discusión » Oracle Database, motor de base de datos profesional  

Cambiar a:  
Key
  Puede publicar nuevos temas en este foro
No puede responder a temas en este foro
No puede editar sus mensajes en este foro
No puede borrar sus mensajes en este foro
No puede votar en encuestas en este foro
Visita nuestro nuevo sitio web con programas y contenidos actualizados: Proyecto A