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 :

Comment convertir un memorystream lu dans un blob en string


Sujet :

Bases de données Delphi

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Juillet 2003
    Messages
    803
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2003
    Messages : 803
    Par défaut Comment convertir un memorystream lu dans un blob en string
    Bonjour,

    A la lecture d'une requête IBQuery sur une IBTable je récupère les données d'un champ déclaré Blob Sub_Type 1 dans un memorystream après l'avoir créé tel que :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
          (FieldByName(CHAMP_BLOB) as tBlobField).SaveToStream(Memorystream);
    J'ai vérifié Memorystream.Size est correct. (61 ko et des brouettes)

    Question : Comment convertir MemoryStream dans un AnsiString, memo, etc. que je puisse lire caractère par caractère ?

  2. #2
    Membre éclairé
    Profil pro
    Inscrit en
    Juillet 2003
    Messages
    803
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2003
    Messages : 803
    Par défaut Voila la solution
    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
     
    function MemoryStreamToString( MS : TMemoryStream ): AnsiString;
    var
      SS: TStringStream;
      format: TStreamOriginalFormat;
    begin
      SS:= TStringStream.Create(Result);
      try
        MS.Seek(0,soFromBeginning);//Se place au début du flux MS.
        format := sofText;
        //Objet binaire contenu dans MS => texte et le place dans SS.
        ObjectBinaryToText(MS,SS, format);
        SS.Seek(0,soFromBeginning);//Se place au début du flux SS.
        Result :=SS.DataString;//On accéde au texte du flux.
      finally
        SS.Free;
      end;
    end;

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

Discussions similaires

  1. Réponses: 5
    Dernier message: 30/10/2008, 10h06
  2. Comment convertir du XML dans un String -> DataSet
    Par jimbolelephan dans le forum C#
    Réponses: 2
    Dernier message: 12/06/2008, 15h28
  3. Comment sauvegarder une JpegImage dans un BLOB de IB ?
    Par colorid dans le forum Bases de données
    Réponses: 1
    Dernier message: 12/02/2008, 18h47
  4. Réponses: 5
    Dernier message: 06/02/2008, 16h01
  5. Comment poster une image dans un blob avec IBStoredProc ?
    Par colorid dans le forum Bases de données
    Réponses: 0
    Dernier message: 02/12/2007, 08h51

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