![]() |
![]() |
| Paypal | FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
|||||||
| Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Buscar | Temas de Hoy | Marcar Foros Como Leídos |
![]() |
|
|
Herramientas | Buscar en Tema | Desplegado |
|
|
|
#1
|
||||
|
||||
|
Puedes retornar el valor insertado, mira aquí:
http://www.firebirdfaq.org/faq29/
__________________
La otra guía de estilo | Búsquedas avanzadas | Etiquetas para código | Colabora mediante Paypal |
|
#2
|
||||
|
||||
|
Gracias por las respuestas. Normalmente el valor de una clave primaria no debería interesarle al usuario final, no son para mirar. Pero en este caso es la excepción, sí necesito mostrar el valor cada vez que se guarda un nuevo registro.
__________________
Lazarus Codetyphon : Desarrollo de aplicaciones Object Pascal, libre y multiplataforma. |
|
#3
|
||||
|
||||
|
Me respondo a mí mismo.
![]() Al final lo que hice fue una chapuza (que funciona ): Luego del POST, guardo la posición del registro actual en un marcador (TBookmark), hago un REFRESH del dataset y luego recupero la posición del registro usando el marcador. Utilizo disablecontrols y enablecontrols en Lazarus para que el usuario no note nada. Todo eso se hace en una fracción de segundo...y así el usuario puede ver el valor que toma el campo autoincrementado para el registro que acaba de guardar.
__________________
Lazarus Codetyphon : Desarrollo de aplicaciones Object Pascal, libre y multiplataforma. |
|
#4
|
||||
|
||||
|
__________________
La otra guía de estilo | Búsquedas avanzadas | Etiquetas para código | Colabora mediante Paypal |
|
#5
|
||||
|
||||
|
Gracias Casimiro por la respuesta.
![]() Al final modifiqué el código y al guardar el registro ejecuto esto en AfterPost: Es otra "chapuza", pero funciona. Utilizo una variable temporal llamada ID para guardar la posición, luego uso locate con esa variable como parámetro de búsqueda. ID es la primary key de la tabla, y teniendo en cuenta que existe un índice para esa columna, el posicionamiento usando LOCATE es prácticamente instantáneo a la vista del usuario final. ![]()
__________________
Lazarus Codetyphon : Desarrollo de aplicaciones Object Pascal, libre y multiplataforma. Última edición por nlsgarcia fecha: 04-12-2014 a las 03:33:23. Razón: Resaltar sintaxis Delphi |
|
#6
|
||||
|
||||
|
Tirón de orejas por no poner las etiquetas al código
![]()
__________________
La otra guía de estilo | Búsquedas avanzadas | Etiquetas para código | Colabora mediante Paypal |
|
#7
|
|||
|
|||
|
No se si te serviria esto:
1. Desde Delphi obtienes el valor del generator + 1, con ello ya actualizas el generador. 2. Con este valor realizas el update. 3. En el trigger controla que si el campo llega como '0' debe de obtenerlo dedes el generator. Un saludo, Joan |
![]() |
| Herramientas | Buscar en Tema |
| Desplegado | |
|
|
Temas Similares
|
||||
| Tema | Autor | Foro | Respuestas | Último mensaje |
| ClientDataSet no muestra AggregateField (Campo agregado)) | Jere_84 | Conexión con bases de datos | 3 | 30-03-2012 23:36:59 |
| No muestra Campo Blob en mi DBGrid | ingabraham | Varios | 2 | 23-03-2010 13:50:16 |
| Busqueda en un campo autoincrementado | Alexandro | Tablas planas | 0 | 20-10-2008 16:52:15 |
| Firebird Suma 2 valores en un campo autoincrementado en insercion de registro | Adrian Murua | Firebird e Interbase | 5 | 03-05-2007 12:16:19 |
| no me muestra un campo actualizado con triggers | pmfras | Firebird e Interbase | 0 | 05-03-2005 17:41:07 |
|