Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > MS SQL Server
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 23-06-2005
Jorge Taveras Jorge Taveras is offline
Miembro
 
Registrado: abr 2004
Ubicación: Santo Domingo
Posts: 68
Poder: 21
Jorge Taveras Va por buen camino
Unhappy No se pudo encontrar la fila para su actualización

No se pudo encontrar la fila asociada desde la ultima vez que se leyo,
tengo un formulario de facturas en delphi 6. Utilizo componentes ado.
Es un master/detail que me funciona lo mas bien salvo que 2 o 3 veces
al dia me da el siguiente mensaje:
No se pudo encontrar la fila para su actualizacion, algunos valores han cambiado asociada desde la ultima vez que se leyo.

Encontré en internet un apartado que sugeria que los campos del detalle que se
usaran en el grid (dbgrid, cod_producto, cantidad, costo, etc) cuyos valores por defecto estubieran declarados en la base de datos, pues que tambien les asignara valores en el evento onNewRecord.

Lo anterior lo hice pero el error persiste. La sugerencia la hacian para programación visual basic y visual c, no para delphi. Esto me urge puesto que hace mi programa inseguro. Espero ayuda lo antes posible.
Responder Con Cita
  #2  
Antiguo 23-06-2005
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Poder: 27
jachguate Va por buen camino
¿Hay varios usuarios conectados concurrentemente a la bd?
__________________
Juan Antonio Castillo Hernández (jachguate)
Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate
Responder Con Cita
  #3  
Antiguo 23-06-2005
Avatar de marcoszorrilla
marcoszorrilla marcoszorrilla is offline
Capo
 
Registrado: may 2003
Ubicación: Cantabria - España
Posts: 11.221
Poder: 10
marcoszorrilla Va por buen camino
La tabla debe de tener una clave primaria, para que el cursor pueda reposicionarse despues de la operación, por otra parte, este tipo de fallos con ADO, suele darse por no tener la versión de las MDAC apropiada.

Un Saludo.
__________________
Guía de Estilo de los Foros
Cita:
- Ça c'est la caisse. Le mouton que tu veux est dedans.
Responder Con Cita
  #4  
Antiguo 23-06-2005
Jorge Taveras Jorge Taveras is offline
Miembro
 
Registrado: abr 2004
Ubicación: Santo Domingo
Posts: 68
Poder: 21
Jorge Taveras Va por buen camino
Es un programa de facturación donde tengo a 3 usuarios conectados al mismo tiempo, captando distintas facturas.

Por cierto, el mensaje es exactamente como lo describo ahora:

No se pudo encontrar la fila para su actualizacion, algunos valores han cambiado desde la ultima vez que se leyó.
Responder Con Cita
  #5  
Antiguo 23-06-2005
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Poder: 27
jachguate Va por buen camino
Cita:
Empezado por Jorge Taveras
No se pudo encontrar la fila para su actualizacion, algunos valores han cambiado desde la ultima vez que se leyó.
A mi el mensaje me parece claro. Algún dato cambió y ADO está generando un Update con todos los campos en el where (no solo la llave) o bien el campo que cambió es parte de la llave.

Trataré de explicarlo con un ejemplo:

Supongamos que tenes una tabla de exisencias, y tu programa, en la caja 1 y en la caja 3 inicia una factura al mismo tiempo, leyendo ambos el siguiente registro:

Código:
Producto    Existencia
--------    -----------
cocacola     50
La caja 3 vende 10 cocacolas y termina primero, ejecutando el siguiente código para actualizar la existencia:

Código Delphi [-]
  tablaExistencia.Edit;
  TablaExistenciaExistencia.AsInteger :=
    TablaExistenciaExistencia.AsInteger - 10;
  TablaExistencia.Post;

Ado prepara y lanza a la base de datos la siguiente sentencia:

Código SQL [-]
Update Existencia
   Set Existencia = 40
 where producto = 'cocacola'
   and existencia = 50;
.

Cuando la caja 1 vende 5 cocacolas, lanzará una sentencia como:

Código SQL [-]
Update Existencia
   Set Existencia = 45
 where producto = 'cocacola'
   and existencia = 50;
.

dado que ella "recordaba" que la existencia era 50, pero este registro en particular ya no existe, lanzando el error que te encontras.

Hay varias formas de evitar este problema. Una, que es la que a mi mas me gusta dado que podemos seguir trabajando en un modelo de bloqueos optimista, es lanzar las actualizaciones desde triggers en la propia base de datos y no desde el programa cliente.

Otra es poner una capa intermedia que serialice las actualizaciones, forzando siempre a refrescar el registro antes de actualizar.

Hay otras, pero no hay mucho tiempo para explicar cada una, espero que con esta información tengas suficiente para investigar por tu cuenta y poner a funcionar tu creatividad.

Hasta luego.

__________________
Juan Antonio Castillo Hernández (jachguate)
Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate
Responder Con Cita
  #6  
Antiguo 23-06-2005
Jorge Taveras Jorge Taveras is offline
Miembro
 
Registrado: abr 2004
Ubicación: Santo Domingo
Posts: 68
Poder: 21
Jorge Taveras Va por buen camino
he leido tus sugerencias. las pondré en practica cuanto me sea posible.
Sobre todo lo de la actualizacion mediante triggers. Al principio la tenia así, pero me daba un error extraño, me explico con un ejemplo:
el cliente 1 compraba 500 pesos y su balance era de 0
el cliente 5 compraba 400 pesos y su balance era de 0.
luego el cliente 1 compraba 200 y su balance era 500 ( no 700 como era correcto).
Luego el cliente 1 compraba 100 y su balance era 700 ( no 800).
En fin. Cuando generaba una actualizacion me hacia la penuntima.

No insistí sobre el tema y .... bueno... me surgió este ahora.
La otra parte que me gustaria que abundaras un poco es cuando dices
"poner una capa intermedia que serialice las actualizaciones, forzando siempre a refrescar el registro antes de actualizar". Me gustaria entender que es serializar las actualizaciones. Y si te refieres a establecer un comando tal como adoproductos.refrech en un envento, digamos en el before_post.
Realmente estaba buscando el error en el detalle de la factura, pero creo que las cosas andan por el maestro de productos al momento de actualizar como lo sugieres en tu buen ejemplo. Siempre agradecido
Responder Con Cita
  #7  
Antiguo 26-06-2005
Jorge Taveras Jorge Taveras is offline
Miembro
 
Registrado: abr 2004
Ubicación: Santo Domingo
Posts: 68
Poder: 21
Jorge Taveras Va por buen camino
Realice un procedimiento almacenado que me actualiza las existencias del maestro de productos. le envio el codigo del produto y la cantidad y el procedimiento le resta la cantidad a la existencia.

Con esto el programa no me ha dado mas errores del que mensioné.
Que haria sin la ayuda del foro. !!!! gracias mil.
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 17:34: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