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 23-05-2007
ramiretor ramiretor is offline
Miembro
 
Registrado: may 2003
Ubicación: México
Posts: 196
Poder: 21
ramiretor Va por buen camino
Problema con TFileStream en Campo Blob

Buenas a todos:
Tengo el siguiente problema, por razones del destino tengo que guardar archivos en un campo de base de datos. Uso Delphi 2006 base de datos DB2 y componentes dbExpress. Despues de intentar por varios métodos, encontramos (porque asi nos lo sugirió alguien en Borland ) que a un TSimpleDataSet se le pueden pasar los parámetros, de la siguiente manera

Código Delphi [-]
procedure GuardaArchivo;
var
  Archivo: TFileStream;
begin
 
  Archivo := TFileStream.Create(MiArchivo, fmOpenRead);
  with SimpleDataSet do
  begin
     DataSet.ParamByName('NUMCIA').AsInteger := NumCia;
     DataSet.ParamByName('USERID').AsInteger := User;
     DataSet.ParamByName('ARCHIVO').LoadFromStream(Archivo, ftBlob);
     Execute;  
  end;

  FreeAndNil(Archivo);

end;

Esta rutina funciona bien, cuando se trata de un solo registro para guardar pero ahora tenemos el problema de que como la llave de esa tabla son los primeros dos parámetros, si en un mismo proceso (queremos guardar el mismo archivo para varios usuarios) marca el error"El archivo está siendo usado por otro proceso" y solo guarda el primer registro

¿Alguien me puede ayudar?
Gracias
__________________
Ernesto R.
Responder Con Cita
  #2  
Antiguo 23-05-2007
Avatar de seoane
[seoane] seoane is offline
Miembro Premium
 
Registrado: feb 2004
Ubicación: A Coruña, España
Posts: 3.717
Poder: 24
seoane Va por buen camino
Se me ocurre lo siguiente:
Código Delphi [-]
Archivo := TFileStream.Create(MiArchivo, fmOpenRead or fmShareDenyWrite);
Así permitimos que el archivo pueda ser abierto varias veces en modo de solo lectura, sin que se produzca ningún error.
Responder Con Cita
  #3  
Antiguo 24-05-2007
ramiretor ramiretor is offline
Miembro
 
Registrado: may 2003
Ubicación: México
Posts: 196
Poder: 21
ramiretor Va por buen camino
Gracias por la ayuda, ya jaló pero era problema de base de datos no del archivo. De todas maneras muchas gracias por el comentario
__________________
Ernesto R.
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
Campo Blob IVAND SQL 4 09-01-2012 11:57:45
Problema con campo memo-->blob kia Firebird e Interbase 1 22-10-2006 11:35:14
Problema con TFileStream pelaorb68 Varios 9 18-10-2006 20:50:45
PRoblema campo Blob Luis Castillo Firebird e Interbase 14 26-12-2005 14:56:56
Problema campo blob rex Varios 2 15-01-2004 16:09:34


La franja horaria es GMT +2. Ahora son las 20:23:05.


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