Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Varios
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Grupo de Teaming del ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 22-11-2006
pjmedina pjmedina is offline
Miembro
 
Registrado: abr 2006
Posts: 84
Poder: 19
pjmedina Va por buen camino
Problema al cargar imagenes

Buenas a tod@s,
he estado mirando en el foro pero no he visto nada que me pueda ayudar.

Tengo dos base de datos, una en firebird y la otra en access y tengo que traspasar cierta información de access a firebird.

Entre todos los campos se encuentra un campo llamado foto del tipo "OBJETO OLE" y tengo que meterlo en un tipo blob de firebird.

He probado varias opciones y no consigo que funcione. Estoy trabajando con Delphi 7. Me urge un monton, a ver si podeis echarme un cabla.


Muchas gracias a tod@s
Responder Con Cita
  #2  
Antiguo 22-11-2006
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[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
¿Puedes explicar cómo estás haciendo el traspaso?
¿Estás programando en Delphi? ¿Estás usando herramientas externas?
__________________
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
  #3  
Antiguo 22-11-2006
pjmedina pjmedina is offline
Miembro
 
Registrado: abr 2006
Posts: 84
Poder: 19
pjmedina Va por buen camino
Exclamation

Código Delphi [-]
dcurso.First;
     while not(dcurso.Eof)do
     begin
       inc(codigo);
              dusuario.Insert;
       dusuario.FieldByName('codigo').Value:=codigo;
       if dcurso.fieldbyname('apellidos').isnull or dcurso.fieldbyname('nombre').isnull then
       dusuario.cancel
       else
       begin
       if not(dcurso.FieldByName('año').IsNull) then         
 dusuario.FieldByName('libre2').Value:=dcurso.fieldbyname('año').asstring;
       dusuario.FieldByName('num_matricula').value:=dcurso.fieldbyname('expte').AsString;       
//AQUI POR EJEMPLO TENDRIA K PONER K PASE LA FOTO SI LA TIENE
        if not(dcurso.FieldByName('fecha nac').IsNull) then  
       dusuario.fieldbyname('fecha_nacimiento').value:=dcurso.FieldByName('fecha nac').Value;       
dusuario.FieldByName('nombre_usuario').Value:=trim(dcurso.FieldByName('apellidos').Value+' '+dcurso.FieldByName('nombre').Value);
dusuario.FieldByName('nombre_completo').Value:=trim(dcurso.FieldByName('apellidos').Value+' '+dcurso.FieldByName('nombre').Value);
dusuario.FieldByName('poblacion').Value:=dcurso.FieldByName('población').Value;       
dusuario.FieldByName('direccion').Value:=dcurso.FieldByName('dirección').Value;      
dusuario.FieldByName('provincia').Value:=dcurso.FieldByName('provincia').Value;       
dusuario.FieldByName('codigo_postal').Value:=dcurso.FieldByName('cp').Value;       
dusuario.FieldByName('telefono').Value:=dcurso.FieldByName('teléfono1').Value;       
dusuario.FieldByName('telefono_2').Value:=dcurso.FieldByName('teléfono2').Value;       
if not(dcurso.FieldByName('nif').IsNull)then
dusuario.FieldByName('nif').Value:=QuitaCaracter(dcurso.fieldbyname('nif').Value);       
dusuario.FieldByName('comentario').Value:=dcurso.FieldByName('observaciones').Value;       
dusuario.FieldByName('libre1').Value:=dcurso.FieldByName('curso').Value;       
dusuario.Post;
        end;
       dcurso.Next;
            end;


Este es el fragmento de codigo principal para el traspaso de lo que quiero. Simpremente recorro todos los campos de la tabla origen (access)y los voy insertando en la tabla destinto (firebird).

El tema de la foto no lo he conseguido pasar.

Última edición por pjmedina fecha: 22-11-2006 a las 16:41:37.
Responder Con Cita
  #4  
Antiguo 22-11-2006
luisgutierrezb luisgutierrezb is offline
Miembro
 
Registrado: oct 2005
Ubicación: México
Posts: 925
Poder: 19
luisgutierrezb Va por buen camino
busca en los metodos del campo blob, las funciones, loadfromstream y savetostream, en la ayuda de delphi
Responder Con Cita
  #5  
Antiguo 23-11-2006
pjmedina pjmedina is offline
Miembro
 
Registrado: abr 2006
Posts: 84
Poder: 19
pjmedina Va por buen camino
Código Delphi [-]
 try       
       MS:=TMemoryStream.Create;       
       dcursofoto.SaveToStream(MS);// Access - OLE - Imagen de mapa de bit
       dusuarioimagen.SaveToStream(MS);//Firebird - Blob
     finally
       MS.Free;
    
 end;


¿Si pongo esto en cada insert debería de funcionar? No entiendo muy bien esto del stream ni del memorystream.

Siento ser pesado pero consigo echarlo a andar.

Ayudarme por favor ...


Gracias
Responder Con Cita
  #6  
Antiguo 23-11-2006
Avatar de Lepe
[Lepe] Lepe is offline
Miembro Premium
 
Registrado: may 2003
Posts: 7.424
Poder: 28
Lepe Va por buen camino
Código Delphi [-]
 try       
       MS:=TMemoryStream.Create;       
       dcursofoto.SaveToStream(MS);// Access - OLE - Imagen de mapa de bit
       dusuarioimagen.LoadFromStream(MS);//Firebird - Blob CAMBIOOOOOOOOO
     finally
       MS.Free;
    
 end;

Un Stream es un "flujo de datos", una tubería desde un origen hacia un destino. También puede servir un Stream para almacenar algo, bien temporalmente o definitivamente.

Existen varios tipos de Stream:
- MemoryStream, crea un "almacén" en memoria RAM
- FileStream, crea un "almacén" en el disco duro.

Con ese código lo que se hace es:
- Crear un espacio en memoria (llamado MS) para poder guardar algo temporalmente; MS es un intermediario de la operación.
- Se accede a dcursofoto y se guarda el contenido (la foto que está en la BBDD) en el Stream de memoria.
- Desde dusuarioimagen se carga el contenido de MS (la foto).
- Por último se elimina de la memoria el "almacén", el MS.

La foto queda en dsusuarioimagen (sea lo que sea, un TImage, Un TStream, ...).
Saludos y espero te ayude a comprender mejor el Stream.
__________________
Si usted entendió mi comentario, contácteme y gustosamente,
se lo volveré a explicar hasta que no lo entienda, Gracias.

Última edición por Lepe fecha: 23-11-2006 a las 14:31:07.
Responder Con Cita
  #7  
Antiguo 23-11-2006
pjmedina pjmedina is offline
Miembro
 
Registrado: abr 2006
Posts: 84
Poder: 19
pjmedina Va por buen camino
Muchas gracias por la información. La verdad que me ha aclarado un monton.

He puesto lo que me has escrito, y el traspaso me lo hace. El problema está a la hora de mostrar la imagen que dice "La imagen Bitmap no es válida".

¿A qué se puede deber esto?



Perdonad por las molestias!!!
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
Cargar imágenes david.rguez Gráficos 0 21-11-2006 13:34:51
Cargar 10 imagenes y utilizarlas Alexander Gráficos 1 05-09-2006 22:06:17
cargar imagenes con FastReports Josemarg Impresión 0 21-07-2006 13:31:17
Cargar multiples imágenes dicatek Gráficos 6 09-07-2006 21:55:27
Cargar imagenes ramonibk Gráficos 7 26-07-2004 16:12:35


La franja horaria es GMT +2. Ahora son las 13:56:22.


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