Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Conexión con bases de datos (https://www.clubdelphi.com/foros/forumdisplay.php?f=2)
-   -   Firebird, autonumerador ID (soy nuevo) (https://www.clubdelphi.com/foros/showthread.php?t=32537)

Mauro® 08-06-2006 20:32:05

Firebird, autonumerador ID (soy nuevo)
 
Hola a todos, estoy empezando a portar mis aplicaciones en paradox a Firebird, el primer problema con el que me encuentro es que no pudo hacer que se autogenere la ID primaria de una tabla, es decir he creado los Tigger y los generadores pero igual desde mi aplicación delphi me dice que no la clave ID no puede ser nula, esto es obvio pero no debería asignarlo firebird, para eso tiene los tiggers y los generadores? Alguien me puede dar una mano con este problema.

Saludos a todos.
Mauro

Sudamericano 08-06-2006 20:40:50

Muestra cual es el codigo del triger para saber si por hay esta el problema

joanajj 08-06-2006 20:46:27

Con un gestor no lopuedes crear???
 
Pregunto,¿ no puedes probar a crear el campo ID autoincrementado con un por ej. IBExpress Personal ??? le das la opción de que el campo sea auto¡ncrementable, le das el valor inicial, y automáticamente se incrementa cada ves que añades un registro a la tabla.


Saludos...

Mauro® 08-06-2006 21:01:40

Asi lo he hecho
 
Si lo hice de esa manera, nada más que con SQL Manager 2005, pero igual no funciona, es decir desde las pruebas tanto sea de IBEpress o SQLManager funciona perfecto, pero desde una aplicación delphi no funciona.
No se si me explico.


Saludos
Mauro

Paoti 08-06-2006 22:06:26

Generadores, trigger, obtener valor
 
Hola compañero.



Si se genera el autoincremento, más no se refleja en delphi, hasta que no hagas un commit; abres y cirres el datset.


Y eso es por la forma de que se genera el autoincremento en trigger,


lo que puedes hacer es:


crearte un procedimiento almacenado que obtenga el generador usado inmediatamente despues de haber hecho el post.


o englobar en un solo procedimiento em insert de la tbla y la obtención del ID autoincrementado.


es decir:

Código SQL [-]
CREATE PROCEDURE PR_OBTENER_ULT_ID_COMPRA 
RETURNS (
    ID_COMPRA INTEGER)
AS
/* Se asigna una variable que se llama ID_compra
   que leera el valor actual del generador
   de la última compra realizada
   Para llamar este generador desde delphi
   se debe de usar esta instrucción:
   SELECT * FROM PR_OBTENER_ULT_ID_COMPRA

   SUSPEND, SU USA PARA QUE EL PROCEDURE
   DEVUELVA EL VALOR DE SALIDA */
BEGIN
  /* Procedure body */
  ID_COMPRA = GEN_ID(GEN_COMPRAS_ID_COMPRAS, 0);
  SUSPEND;
END

con esto puedes obtener el id asignado...



A TODOS LOS COMPAÑEROS, QUE USAN FIREBIRD O INTERBASE. QUE HACEN ANTE ESTAS SITUACIONES.

UN CASO PRACTICO ES CUANDO TIENELAS TABLAS EL MAESTRO Y EL DATALLE , Y EN EL MAESTRO, UNA VEZ QUE DAS DE ALTA NO TIENES SU NUEVO ID, PARA PODER INSERTAR EL DETALLE CON ESE ID DEL PADRE.


espero haberme explicado.


Saludos desde Guadalajara


La franja horaria es GMT +2. Ahora son las 13:13:41.

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