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)
-   -   Uso de post con Firebird (https://www.clubdelphi.com/foros/showthread.php?t=91115)

martin17476 14-11-2016 17:40:57

Uso de post con Firebird
 
Hola a todos, tengo una aplicación en paradox y Delphi 2010 la cual estoy pasando a Firebird (con Zeos). Ya tengo todas las tablas en Firebird y en general el programa va funcionando con el código original con pequeñas correcciones. Pero me he encontrado con un problema: cuando actualizo un registro de una tabla mediante un post, el cursor se pierde y parece que va al primer registro de la tabla y pierdo el registro actual.

Seguro que se debe a mi inexperiencia con Firebird; quiza haya que hacer algo más. ¿Alguien me puede indicar como resolver este problema? Gracias

AgustinOrtu 14-11-2016 18:40:45

Parece extraño, hay algun indice en el DataSet? Usas Insert o Append para crear el nuevo registro?

Hay algun evento que se dispare despues del Post? Como refrescas los datos en pantalla luego del Post? Pon el codigo que usas para grabar y los eventos y propiedades relevantes

Lo que podes hacer es usar un TBookmark

Código Delphi [-]
procedure ...
var
  bkm: TBookmark;
begin
  bkm := TuDataSet.GetBookmark; // guarda la posicion actual en el DataSet
  try
    // realizar el post
  finally
    TuDataSet.GotoBookmark(bmk); // volver a posicionarse en donde estabas antes
    TuDataSet.FreeBookmark(bkm); // liberar memoria
  end;
end;

Mas info sobre Bookmarks

martin17476 15-11-2016 07:35:14

Muchas gracias Agustin. Paso a explicarte la situación:

El Dataset no tiene índices.
Uso append.
No hay eventos asociados al post.
No uso pantalla con esta porción de código.
Porción de código:
Código Delphi [-]
Table1.Append;
Table1.Campo1 := var1;
....
Table1.Post;
....
valor1 := Table1.Campo1;
....

Aquí da el fallo. Valor 1 recibe valor 0, cuando debería recibir otro. Este campo1 es la clave primaria y es autoincrement.
He comprobado el valor de Table1.Campo1 y es correcto.

He usado BookMark y tampoco funciona.

Esto no se refleja en pantalla. Con otra tabla, que si refleja en pantalla, y que tiene un campo autoincrement y es clave primaria, para ver dicho valor, he de hacer post y después refrescar.

Espero que tengas toda la información que necesitas.

Neftali [Germán.Estévez] 15-11-2016 09:05:34

Cita:

Empezado por martin17476 (Mensaje 510737)
cuando actualizo un registro de una tabla mediante un post, el cursor se pierde y parece que va al primer registro de la tabla y pierdo el registro actual.

Cuando realizas un Edit+Post (UPDATE) no debería moverse el puntero sobre el que está el registro, a no ser que posteriormente realices un REFRESH (o similar).
Si realizas un REFRESH, tal y como te comenta Agustín, para recuperar el registro que estaba activo, debes utilizar Bookmarks.

Neftali [Germán.Estévez] 15-11-2016 09:11:03

Por favor, utiliza TAG's cuando añadas código Delphi.

Cita:

Empezado por martin17476 (Mensaje 510769)
El Dataset no tiene índices.
Uso append.

Estábamos hablando de UPDATE, ahora hablamos de APPEND (insertar uno nuevo), que son cosas diferentes.


Cita:

Empezado por martin17476 (Mensaje 510769)
Aquí da el fallo. Valor 1 recibe valor 0, cuando debería recibir otro. Este campo1 es la clave primaria y es autoincrement.
He comprobado el valor de Table1.Campo1 y es correcto.

Es normal, porque ese valor no lo asignas tú, sino que al ser autoincrement lo asigna la Base de Datos de forma automática cuando se inserta el registro. Por lo tanto, para saber qué valor ha asignado la Base de Datos, debes hacer un Refresh o consultar manualmente ese valor asignado.



Cita:

Empezado por martin17476 (Mensaje 510769)
Esto no se refleja en pantalla. Con otra tabla, que si refleja en pantalla, y que tiene un campo autoincrement y es clave primaria, para ver dicho valor, he de hacer post y después refrescar.

Correcto. Pues eso justo es lo que has de hacer aquí.

¿Entonces cual es el problema?

martin17476 15-11-2016 16:11:52

Gracias a todos por vuestra ayuda. Siento no haber usado el TAG de Delphi.
Leyendo con atención todo lo que habéis compartido aún sigue habiendo problemas. El código que he usado es:

Código Delphi [-]
Table1.Insert;
Table1.Campo2 := Valor2; //el Campo1 sería el Autoincrement
........
Table1.Post;
marca := Table1.GetBookmark;
Table1.Refresh;
table1.GotoBookMark(marca);
.....

Ahora el valor del campo Autoincrement no es 0, sino que corresponde al valor del último registro físico de la tabla, y no con el que acabo de insertar (el cual ha ido a otro lugar de la tabla).

Lo he resuelto con un Locate:

Código Delphi [-]
Table1.Post;
intCam := table1Camp.Value;
Table1.Refresh;
Table1.Locate('Camp',intCam,[]);

Ahora sí que voy al registro y el valor Autoincrement sí que es el correcto.

Pero sigo pensando que algo no va bien. Debería funcionar con el primer código.

Espero haberme explicado bien. Cualquier observación será de ayuda.


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

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