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 13-05-2004
Avatar de weke
weke weke is offline
Miembro
 
Registrado: may 2004
Ubicación: Valencia
Posts: 170
Poder: 21
weke Va por buen camino
Question Error al modificar campo de una Tabla

¡¡¡Buenas!!!
A la hora de actualizar un campo de una tabla, es un campo donde guardo la ruta de acceso a una imagen para más tarde cargarla en un DBImage.

Cuando inserto la fila, aunque este en blanco este campo no tengo ningún problema.
Una vez insertado, tengo un botón con el que puedo asignarle una imagen. La cuestión es que cuando se la asigno por primera vez me modifica el campo perfectamente y me muestra la imagen. Pero si vuelvo a darle al botón para cambiar otra vez la imagen me da un error.

El error en cuestión que me da es el siguiente:
"Couldn't perform the edit because another user changed the record"
Pero lo más fuerte de todo, es que la imagen si me la modifica bien y la próxima vez que miro la imagen que tiene es la última que he puesto.

A continuación os pongo el código a ver si es que me falta alguna instrucción.
Código:
  
  if (archivo <> '') then
  begin
	elemento:=DBGrid1.Fields[0].AsString;
	elemento2:=DBGrid1.Fields[1].AsString;
	elemento3:=DBGrid1.Fields[2].AsString;
	Table1.First;
	esta:=Table1.FindKey([elemento,elemento2,elemento3]);
	if (esta = true) then
	begin
	  Table1.CachedUpdates:=True;
	  Table1.Edit;
	  Table1.FieldbyName('Foto').AsString:=archivo;
	  Table1.Post;
	  Table1.ApplyUpdates;
	  DBGrid1.Refresh;
	  ShowMessage('La imagen se ha asignado correctamente.');
	  if (DBGrid1.Fields[8].AsString <> '') then
		DBImage1.Picture.LoadFromFile(DBGrid1.Fields[8].AsString);
	end
	else
	  ShowMessage('No se ha podido asignar la imagen a este registro.');
  end;
Nota: archivo, es el nombre del fichero que obtengo con un opendialog. elemento, elemento2 y elemento3 son los campos que forman la clave primaria de la tabla, y los utilizo para situarme en la fila correcta. Esto es solo para que sepais de donde sale cada cosa, que a veces puede llevar a confusión.

Muchas gracias y un saludo a todos.
__________________
De lo bueno lo mejor, de lo mejor lo superior.
Responder Con Cita
  #2  
Antiguo 13-05-2004
__cadetill __cadetill is offline
Miembro
 
Registrado: may 2003
Posts: 3.387
Poder: 25
__cadetill Va por buen camino
Algunos comentarios

Qué linea te da el error?
Por que usas un TDBImage si la imagen no está en la base de datos? Usa un TImage!!

Cita:
Empezado por weke
....que a veces puede llevar a confusión
Bueno, esto no pasaría si nos acostumbráramos a usar nombre de variables y de componentes algo más descriptivos, no crees?

Por otro lado, la variable esta te la puedes ahorrar

Código Delphi [-]
if Table1.FindKey([elemento,elemento2,elemento3]) then
begin

Espero te sirvan estos comentarios
Responder Con Cita
  #3  
Antiguo 14-05-2004
Avatar de weke
weke weke is offline
Miembro
 
Registrado: may 2004
Ubicación: Valencia
Posts: 170
Poder: 21
weke Va por buen camino
Thumbs up

Con respecto a lo de las variables, estoy de acuerdo, pero a veces pongo lo primero que me sale, quizá debería acostumbrarme como tu dices.

Acabo de solucionar el problema. Como me decía que había sido modificado por otro usuario, lo único que he hecho es cerrar y volver a abrir la tabla después de aplicar los cambios y ya no me sale ningún error.



Gracias y un saludo.
__________________
De lo bueno lo mejor, de lo mejor lo superior.

Última edición por weke fecha: 14-05-2004 a las 11:23:56.
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 12:13:04.


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