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

PL/SQL Oracle Discussion :

Lecture d'un fichier BLOB


Sujet :

PL/SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    102
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 102
    Par défaut Lecture d'un fichier BLOB
    Bonjour,

    J'ai besoin de extraire un fichier BLOB stocké dans ma base. Le schéma de ma table est TB_EDITION(ID vrachar(10), CONTENU Blob).
    mon objectif est d'extraire avec PL/SQL le contenu de ce BLOB.
    j'ai essayé le code suivant
    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
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    DECLARE
      l_file      UTL_FILE.FILE_TYPE;
      l_buffer    RAW(32767);
      l_amount    BINARY_INTEGER := 32767;
      l_pos       INTEGER := 1;
      l_blob      BLOB;
      l_blob_len  INTEGER;
    BEGIN
      -- Get LOB locator
      SELECT CONTENU
      INTO   l_blob
      FROM  PFI.TB_EDITION 
      WHERE  ID=21189 
     
      l_blob_len := DBMS_BLOB.getlength(l_blob);
     
      -- Open the destination file.
      l_file := UTL_FILE.fopen('/home/x014340/EXPORT_HIST/','test.pdf','w', 32767);
     
      -- Read chunks of the BLOB and write them to the file
      -- until complete.
      WHILE l_pos < l_blob_len LOOP
        DBMS_LOB.read(l_blob, l_amount, l_pos, l_buffer);
        UTL_FILE.put_raw(l_file, l_buffer, TRUE);
        l_pos := l_pos + l_amount;
      END LOOP;
     
      -- Close the file.
      UTL_FILE.fclose(l_file);
     
    EXCEPTION
      WHEN OTHERS THEN
        -- Close the file if something goes wrong.
        IF UTL_FILE.is_open(l_file) THEN
          UTL_FILE.fclose(l_file);
        END IF;
        RAISE;
    END;
    mais l'erreur suivant s'affiche.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    l_blob_len := DBMS_BLOB.getlength(l_blob);
      *
    ERREUR à la ligne 15 :
    ORA-06550: Ligne 15, colonne 3 :
    PL/SQL: ORA-00933: la commande SQL ne se termine pas correctement
    ORA-06550: Ligne 10, colonne 3 :
    PL/SQL: SQL Statement ignored
    la version oracle est : 10

    Merci d'avance

  2. #2
    Expert confirmé
    Avatar de SheikYerbouti
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    6 760
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 6 760
    Par défaut
    Bonjour,

    le but du forum n'est pas vraiment le débugage de code.
    Il parait écident, ici,que l'ordre SELECT précédent ne se termine pas par un point-virgule.

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    102
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 102
    Par défaut Lecture d'un fichier BLOB
    Je vous remecie
    En fait mon but est d'extraire les données d'un BLOB dans un PDF.
    J'ai cherché une solution sur INTRNET et j'ai trouvé le code que j'ai mis dans mon message précédent. cependant, ce code ne fonctionne pas.

    Je vous serai reconnaissant si vous pouvez me proposer une solution

    Bien cordialement
    ammah

  4. #4
    Expert confirmé
    Avatar de SheikYerbouti
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    6 760
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 6 760
    Par défaut
    Citation Envoyé par ammah Voir le message
    En fait mon but est d'extraire les données d'un BLOB dans un PDF.
    Vous voulez-dire dans un fichier extérieur à la base ? le BLOB contient déjà un fichier au format PDF ?

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    102
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 102
    Par défaut Lecture d'un fichier BLOB
    Le BLOB contient un fichier PDF zippé. LE zip est fait avec des biliothéque Java.

  6. #6
    Expert confirmé
    Avatar de SheikYerbouti
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    6 760
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 6 760
    Par défaut
    Donc vous voulez extraire le contenu du BLOB sur le disque, c'est ça ?

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

Discussions similaires

  1. Lecture d'un fichier en binaire pour stockage BLOB
    Par crocotim dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 19/07/2007, 14h20
  2. Réponses: 6
    Dernier message: 02/09/2003, 15h12
  3. Lecture et ecriture fichier .ini
    Par despe dans le forum C
    Réponses: 6
    Dernier message: 23/07/2003, 20h40
  4. [langage] Optimiser la lecture d'un fichier
    Par And_the_problem_is dans le forum Langage
    Réponses: 4
    Dernier message: 05/02/2003, 08h54
  5. [langage] Optimiser la lecture d'un fichier
    Par And_the_problem_is dans le forum Langage
    Réponses: 2
    Dernier message: 11/06/2002, 10h24

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