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
  #7  
Antiguo 02-03-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 a todos y gracias por sus respuestas y sugerencias,

He probado como mi amigo Gallosuarez me ha indicado, pero me aparece el siguiente error que me lanza IBExpert
Código SQL [-]
---------- STATEMENT ----------

CREATE trigger contable_bi0 for contable
active before insert position 0
AS
begin
  /* Trigger text */
  SELECT GEN_ID(gen_contrataciones, (SELECT (GEN_ID(gen_contrataciones, 0) * -1) FROM RDB$DATABASE)) FROM RDB$DATABASE;
  SELECT GEN_ID(gen_contrataciones, new.concontrato) FROM RDB$DATABASE;
end



---------- ERROR MESSAGE ----------

Invalid token.
Dynamic SQL Error.
SQL error code = -104.
Token unknown - line 6, column 119.
;.

Gracias por vuestro tiempo y vuestra ayuda

Gustavo Cruz
Responder Con Cita
  #8  
Antiguo 02-03-2011
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Poder: 26
guillotmarc Va por buen camino
Buenas tardes.

Cita:
Empezado por GustavoCruz Ver Mensaje
Hola a todos y gracias por sus respuestas y sugerencias,

He probado como mi amigo Gallosuarez me ha indicado, pero me aparece el siguiente error que me lanza IBExpert
Probablemente porqué lo ejecutas como una consulta y es un script.

Prueba a ejecutarlo desde Tools -> Script Executive, en lugar de hacerlo desde Tools -> SQL Editor.

Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no).
Responder Con Cita
  #9  
Antiguo 03-03-2011
Gallosuarez Gallosuarez is offline
Miembro
 
Registrado: feb 2007
Posts: 92
Poder: 20
Gallosuarez Va por buen camino
Talking Posible solución ...

Gustavo:

Acuérdate que TODA instrucción SELECT dentro de un bloque PSQL debe de llevar la clausula INTO :valor_de_variable. Es por esta razón que te marca un error en ";" Es decir, el compilador de la base de datos está esperando dicha instrucción.

Aquí te pongo un procedimiento donde yo lo utilizo.
Código SQL [-]
CREATE OR ALTER PROCEDURE CALC_CTRL_SEP
RETURNS (
    CTRL_SEP VARCHAR(14))
AS
declare variable aa char(2);
declare variable id_u_admtva char(1);
declare variable entidad char(2);
declare variable id_estado smallint;
declare variable tipo_plantel char(2);
declare variable no_plantel char(3);
declare variable consecutivo smallint;
begin
/* Calcula el Número de Control SEP de acuerdo a los parámetros del sistema */
  select id_u_admtva, id_estado, tipo_plantel, no_plantel
  from sysparams into :id_u_admtva, :id_estado, :tipo_plantel, :no_plantel;
  consecutivo = next value for gen_ctrl_sep;
/* Resetea gen_ctrl_sep = 0 */
  if (consecutivo > 9999) then
  begin
    select gen_id(gen_ctrl_sep, (select (gen_id(gen_ctrl_sep, 0) * -1)
    from rdb$database)) from rdb$database into :consecutivo;
    consecutivo = next value for gen_ctrl_sep;
  end
  entidad = lpad(cast(id_estado as varchar(2)), 2, '0');
  aa = right(cast(extract(year from current_date) as char(4)), 2);
  CTRL_SEP = aa || id_u_admtva || entidad || tipo_plantel ||
    no_plantel || lpad(cast(consecutivo as varchar(4)), 4, '0');
end

Saludos,
Gerardo Suárez Trejo.

PD. En tu caso, debes de utilizar las llamadas variables Tontas ... ¿me explico?
Responder Con Cita
  #10  
Antiguo 03-03-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
Gracias Gallosuarez, por tu colaboración. Eso era exactamente lo que estaba ocurriendo.

He notado que ultimamente sufro de segera

Nuevamente mil gracias por sus sugerencias y respuestas


Gustavo Cruz
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 20:49:52.


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