IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Bases de données Delphi Discussion :

[ADO]Transfert image dans champ blob


Sujet :

Bases de données Delphi

  1. #1
    Membre régulier Avatar de dleu
    Profil pro
    Inscrit en
    Août 2004
    Messages
    169
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Août 2004
    Messages : 169
    Points : 77
    Points
    77
    Par défaut [ADO]Transfert image dans champ blob
    Bonjour,

    Pour transférer une string d'un edit à un champ Ado on fait :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    AdoQuery1.FieldByName('Format').AsString:=Edit6.Text;
    Mais pour transférer une image d'un Timage dans un champ blob, comment fait-on ?

    J'ai essayé:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    AdoQuery1.FieldByName('Photo').Assign(Image1.Picture);
    mais cela ne marche pas.

    Comment dois-je faire ?

    Merci de votre aide.

    Didier

    ɹəᴉpᴉp

  2. #2
    Rédacteur
    Avatar de Giovanny Temgoua
    Profil pro
    Étudiant
    Inscrit en
    Novembre 2003
    Messages
    3 830
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2003
    Messages : 3 830
    Points : 4 006
    Points
    4 006
    Par défaut
    Bonsoir,

    En général je passe par CreateBlobStream pour manipuler le champ blob. As-tu essayé cette méthode ?

  3. #3
    Membre régulier Avatar de dleu
    Profil pro
    Inscrit en
    Août 2004
    Messages
    169
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Août 2004
    Messages : 169
    Points : 77
    Points
    77
    Par défaut
    Salut,

    Honêtement, je ne sais pas trop bien comment m'y prendre avec ce CreateBlobStream.

    Pourrais-tu m'expliquer un peu comment je dois procéder ?

    Merci.

    Didier

    ɹəᴉpᴉp

  4. #4
    Membre régulier Avatar de dleu
    Profil pro
    Inscrit en
    Août 2004
    Messages
    169
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Août 2004
    Messages : 169
    Points : 77
    Points
    77
    Par défaut
    Pour lire d'une table, j'ai ce code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    var blob: TBLOBStream;
     
    blob := Table1.CreateBlobStream(Table1.FieldByName('Photo'), bmRead);
    try
      blob.Seek(0, soFromBeginning);
      image1.Picture.Bitmap.LoadFromStream(blob);
    finally
      blob.Free;
    end;
    Mais comment puis-je faire pour écrire dans la table ? Je n'arrive pas à créer un code qui fonctionne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    var blob: TBLOBStream;
     
    blob := Table1.CreateBlobStream(Table1.FieldByName('Photo'), bmWrite);
    try
      blob.Seek(0, soFromBeginning);
      Image1.Picture.Bitmap.SaveToStream(blob);
    finally
      blob.Free;
    end;
    Je sèche là.

    Didier

    ɹəᴉpᴉp

  5. #5
    Membre régulier Avatar de dleu
    Profil pro
    Inscrit en
    Août 2004
    Messages
    169
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Août 2004
    Messages : 169
    Points : 77
    Points
    77
    Par défaut
    Pour ceux que cela intéresse voilà la solution que j'ai trouvée grace à un gros coup de pouce de King Kaiser (Merci encore à lui) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
     
    var
       blob : TStream;
       jpg : TJpegImage;
    ...
    ...
    ...
        try
        	jpg:=TJpegImage.Create;
          try
        		blob :=CreateBlobStream(FieldByName('Photo'), bmWrite);
    				try
        			jpg.Assign(Image1.Picture);
          		blob.Seek(0, soFromBeginning);
      				jpg.SaveToStream(blob);
            except
            	MessageBox(RechercheInternet.Handle,'Impossible d''enregistrer l''image !',
                  'Erreur', mb_OK + mb_IconExclamation);
            end;
          finally
      			blob.Free;
    			end;
        finally
         	jpg.free;
      	end;
        Post;
    Voilà.

    A+

    Didier

    ɹəᴉpᴉp

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 3
    Dernier message: 24/02/2010, 00h53
  2. [MySQL] Récuperer une image dans champs BLOB de la base de données
    Par gilou31 dans le forum PHP & Base de données
    Réponses: 16
    Dernier message: 28/02/2008, 16h32
  3. Réponses: 1
    Dernier message: 24/08/2007, 12h48
  4. [Oracle] Ecriture dans champ BLOB de fichiers joints par formulaire
    Par mcshu dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 08/02/2007, 14h33
  5. Fichier binaires dans champ blob
    Par divparzero dans le forum C++Builder
    Réponses: 5
    Dernier message: 30/01/2007, 16h25

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo