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 04-09-2003
erickperez6 erickperez6 is offline
Miembro
 
Registrado: may 2003
Posts: 152
Poder: 22
erickperez6 Va por buen camino
User abort con applyupdates

Saludos !

estoy utilizando un IBquery conectado a un IBUpdateSql, utilizo el cachedupdate en true, la tabla1 con que estoy trabajando en los componentes ya mencionados tiene una referencia foranea, es decir, que no puedo eliminar un registro si tiene una referencia en la tabla2.

El problema es el siguiente, si mantengo desactivado el cachedupdate, al momento de eliminar el registro, si este tiene una referencia en la tabla2, interbase me arroja el error tipico cuando se trata de violar una referencia, todo hasta aqui va muy bien, pero cuando activo el cachedupdate a true (es la manera en la cual deseo trabajar), al momento de borrar el mismo registro no me arroja ningun error, pero al momento de postear el applyupdates me arroja el error de "User abort" y ningun cambio que haya hecho a otro registro se aplica, ni nada de nada !

Alguna manera de evitar esto utilizando el cachedupdate en true ?

Gracias
Responder Con Cita
  #2  
Antiguo 04-09-2003
Avatar de kinobi
kinobi kinobi is offline
Miembro
 
Registrado: may 2003
Posts: 2.621
Poder: 24
kinobi Va por buen camino
Hola,

en principio parace un problema en el lado cliente (por el uso de actualizaciones en caché), así que muevo el hilo desde el foro "Interbase y Firebird" al foro "Conexión con bases de datos".

Saludos.
Responder Con Cita
  #3  
Antiguo 08-09-2003
andres1569 andres1569 is offline
Miembro
 
Registrado: may 2003
Posts: 908
Poder: 22
andres1569 Va por buen camino
Hola:

Evidentemente, el usar CachedUpdates hace que la detección de errores que dejamos al servidor, como en este caso, se posponga al momento de hacer ApplyUpdates.

¿Soluciones? Se me ocurre o bien que esa comprobación de clave foránea la hagas desde la aplicación lanzando una consulta, o bien que interceptes el evento OnUpdateError de la tabla correspondiente. Ahí puedes chequear el problema y "desborrar" el registro involucrado (creo que para ello te puede servir el método RevertRecord) y pones, en dicho evento, UpdateAction a uaRetry para que vuelva a intentarse la grabación de lo que tenías en la cache, de esa forma el resto de modificaciones no se ven perjudicadas.

Saludos
__________________
Guía de Estilo
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


La franja horaria es GMT +2. Ahora son las 14:46:01.


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