![]() |
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 |
Muestra cual es el codigo del triger para saber si por hay esta el problema
|
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... |
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 |
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:
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 07:32:59. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi