Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Conexión con bases de datos
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Conexión con bases de datos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 14-11-2016
martin17476 martin17476 is offline
Miembro
 
Registrado: oct 2006
Posts: 27
Poder: 0
martin17476 Va por buen camino
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
Responder Con Cita
  #2  
Antiguo 14-11-2016
Avatar de AgustinOrtu
[AgustinOrtu] AgustinOrtu is offline
Miembro Premium
NULL
 
Registrado: ago 2013
Ubicación: Argentina
Posts: 1.858
Poder: 15
AgustinOrtu Es un diamante en brutoAgustinOrtu Es un diamante en brutoAgustinOrtu Es un diamante en brutoAgustinOrtu Es un diamante en bruto
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
Responder Con Cita
  #3  
Antiguo 15-11-2016
martin17476 martin17476 is offline
Miembro
 
Registrado: oct 2006
Posts: 27
Poder: 0
martin17476 Va por buen camino
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.

Última edición por Neftali [Germán.Estévez] fecha: 15-11-2016 a las 09:07:10. Razón: Añadir etiquetas
Responder Con Cita
  #4  
Antiguo 15-11-2016
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is online now
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.272
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
Cita:
Empezado por martin17476 Ver Mensaje
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.
__________________
Germán Estévez => Web/Blog
Guía de estilo, Guía alternativa
Utiliza TAG's en tus mensajes.
Contactar con el Clubdelphi

P.D: Más tiempo dedicado a la pregunta=Mejores respuestas.
Responder Con Cita
  #5  
Antiguo 15-11-2016
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is online now
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.272
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
Por favor, utiliza TAG's cuando añadas código Delphi.

Cita:
Empezado por martin17476 Ver Mensaje
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 Ver Mensaje
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 Ver Mensaje
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?
__________________
Germán Estévez => Web/Blog
Guía de estilo, Guía alternativa
Utiliza TAG's en tus mensajes.
Contactar con el Clubdelphi

P.D: Más tiempo dedicado a la pregunta=Mejores respuestas.
Responder Con Cita
  #6  
Antiguo 15-11-2016
martin17476 martin17476 is offline
Miembro
 
Registrado: oct 2006
Posts: 27
Poder: 0
martin17476 Va por buen camino
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.
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
Comit vrs Post sancarlos MySQL 6 14-05-2008 10:13:08
POST sin boton ZayDun HTML, Javascript y otros 1 19-04-2008 11:33:46
Post o CheckBrowseMode ? David Conexión con bases de datos 3 30-08-2007 03:14:15
IBDatase Insert Post Edit Post ariefez Firebird e Interbase 4 12-10-2005 01:53:04
Componente Post-it Legolas Gráficos 3 05-12-2003 16:49:47


La franja horaria es GMT +2. Ahora son las 09:17:43.


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
Copyright 1996-2007 Club Delphi