Club Delphi  
    Paypal   FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > Firebird e Interbase
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 24-02-2011
Avatar de GustavoCruz
GustavoCruz GustavoCruz is offline
Miembro
 
Registrado: jul 2006
Ubicación: Sampués Sucre (Colombia)
Posts: 296
Poder: 20
GustavoCruz Va por buen camino
Restaurar valor de un generador

Buenas tardes amigos foreros.

Pues el título lo dice todo. Me gustaría saber cómo hago para restaurar el valor un generador.

Mil gracias por vuestra ayuda

GustavoCruz
Responder Con Cita
  #2  
Antiguo 24-02-2011
Avatar de Casimiro Noteví
Casimiro Noteví Casimiro Noteví is offline
Merodeador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.671
Poder: 10
Casimiro Noteví Tiene un aura espectacularCasimiro Noteví Tiene un aura espectacular
El sistema "de toda la vida":

SET GENERATOR GEN_TBTIPOSIVA_ID TO 0;

El nuevo sistema desde FB 2.1:

ALTER SEQUENCE GEN_TBTIPOSIVA_ID RESTART WITH 0;
Responder Con Cita
  #3  
Antiguo 26-02-2011
Avatar de GustavoCruz
GustavoCruz GustavoCruz is offline
Miembro
 
Registrado: jul 2006
Ubicación: Sampués Sucre (Colombia)
Posts: 296
Poder: 20
GustavoCruz Va por buen camino
Hola Casimiro Notevi, gracias por tu respuesta.

He intentado como me sujeriste y me muestra un error. Lo que quiero hacer es que cuando en un determinado momento y inserte un valor en una tabla, este valor sea tomado por el generador. Esto es porque necesito controlar unos datos que se generarán anualmente, De este modo; Tengo una tabla de configuraciones en la cual hay un campo que me almacena el inicio de una numeración y este valor ser debe reiniciar cada año, o cuando el usuario lo decida en la cantidad que él quiera.

Me imaginé que eso se solucionaba con un trigger. pero la sentencia que me sugieres no es me está funcionando.


Saludos y Mil gracias por tu tiempo


Gustavo Cruz
Responder Con Cita
  #4  
Antiguo 26-02-2011
Avatar de Casimiro Noteví
Casimiro Noteví Casimiro Noteví is offline
Merodeador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.671
Poder: 10
Casimiro Noteví Tiene un aura espectacularCasimiro Noteví Tiene un aura espectacular
Cita:
Empezado por GustavoCruz Ver Mensaje
He intentado como me sujeriste y me muestra un error.
¿Qué error?, eso no puede dar ningún error.
SET GENERATOR GEN_TBTIPOSIVA_ID TO 0;
Evidentemente GEN_TBTIPOSIVA_ID debes sustituirlo por el nombre de tu generador.

Cita:
Empezado por GustavoCruz Ver Mensaje
Lo que quiero hacer es que cuando en un determinado momento y inserte un valor en una tabla, este valor sea tomado por el generador
Creo que no te entiendo, el valor del campo de la tabla es el que coge el valor del generador, no al revés.

Y si quieres hacerlo al revés, entonces dale el valor que quieras:
SET GENERATOR GEN_TBTIPOSIVA_ID TO 38374384;
Responder Con Cita
  #5  
Antiguo 26-02-2011
Gallosuarez Gallosuarez is offline
Miembro
 
Registrado: feb 2007
Posts: 92
Poder: 20
Gallosuarez Va por buen camino
Talking Posible solución ...

Gustavo:

Para reiniciar a cero un generador desde un bloque PSQL (es decir desde un procedimiento almacenado o desde un disparador), tienes que ejecutar la siguiente instrucción:
Código SQL [-]
SELECT GEN_ID(NOMBRE_GENERADOR, (SELECT (GEN_ID(NOMBRE_GENERADOR, 0) * -1) FROM RDB$DATABASE)) FROM RDB$DATABASE

Una vez que lo hayas reiniciado a cero le puedes sumar cierta cantidad para ponerlo a cierto valor.

Código SQL [-]
SELECT GEN_ID(NOMBRE_GENERADOR, NUEVO_VALOR) FROM RDB$DATABASE

Saludos,
Gerardo Suárez Trejo

PD. No estoy muy seguro si la solución que te da Casimiro funcione haciendo lo desde un bloque PSQL, según yo creo que no.... saludos nuevamente
Responder Con Cita
  #6  
Antiguo 26-02-2011
Avatar de Casimiro Noteví
Casimiro Noteví Casimiro Noteví is offline
Merodeador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.671
Poder: 10
Casimiro Noteví Tiene un aura espectacularCasimiro Noteví Tiene un aura espectacular
Perdón, no había leído "desde un trigger"
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Captura del Valor de un Generador servicomp Firebird e Interbase 5 05-07-2010 17:36:30
Actualizar un valor en un generador desde un Sp muli Firebird e Interbase 16 11-06-2008 14:56:05
Procedimieto para averiguar el valor de un generador en firebird Mauro® Conexión con bases de datos 4 15-12-2006 01:09:05
Insertar valor generador Luis Castillo Firebird e Interbase 1 04-01-2006 15:02:49
Como Obtener el valor de mi Generador NickName Firebird e Interbase 2 26-07-2003 19:54:50


La franja horaria es GMT +2. Ahora son las 17:46:37.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi