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 :

Régénérer un fichier à partir d'un blob


Sujet :

PL/SQL Oracle

  1. #1
    Futur Membre du Club
    Inscrit en
    Mai 2008
    Messages
    9
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 9
    Points : 6
    Points
    6
    Par défaut Régénérer un fichier à partir d'un blob
    bonjour ,
    j'aimerai regenerer un fichier xml à partir d'un blob, sans perte dûe au bug <Bug:2546782> du package UTL_FILE.

    merci d'avance

  2. #2
    Expert éminent sénior
    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
    Points : 11 862
    Points
    11 862
    Par défaut
    version de la BDD ?

  3. #3
    Membre actif Avatar de DAB.cz
    Inscrit en
    Octobre 2006
    Messages
    221
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 221
    Points : 249
    Points
    249

  4. #4
    Futur Membre du Club
    Inscrit en
    Mai 2008
    Messages
    9
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 9
    Points : 6
    Points
    6
    Par défaut
    oracle 9i2

  5. #5
    Expert éminent sénior
    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
    Points : 11 862
    Points
    11 862
    Par défaut
    Je ne sais si cela vous aidera, mais voici la proc que j'utilise pour enregistrer un fichier binaire sur le disque. Je prends des chunks de 16Ko, donc pas de problème:

    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
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    CREATE OR REPLACE PROCEDURE Write_Binary_File
      (
         PC$Directory IN VARCHAR2 
        ,PC$File_Name IN VARCHAR2 
        ,PC$SQL_Order IN VARCHAR2 
        ,PB$Raise     IN BOOLEAN  DEFAULT FALSE
      )
      --  -------------------------------------------
      --  Procedure to dump a BLOB column onto a file
      --  -------------------------------------------
      --  parameters:
      --  PC$Directory : name of an existing Oracle Directory
      --  PC$File_Name : name of the expected output file
      --  PC$SQL_Order : SQL order to select the BLOB column
      --  PB$Raise     : boolean to indicate if the process
      --                 would be stopped after an error
      --
       IS
        src_lob      BLOB;
        buffer       RAW(16384);
        amt          BINARY_INTEGER := 16384;
        pos          INTEGER := 1;
        LF$FicOUT     UTL_FILE.FILE_TYPE ;
        LC$Msg       VARCHAR2(2000) ;
      BEGIN
     
        -- get the BLOB column --
        BEGIN
          EXECUTE IMMEDIATE PC$SQL_Order INTO src_lob ;
        EXCEPTION
          WHEN NO_DATA_FOUND THEN
            LC$Msg := 'Write_Binary_File(): NO_DATA_FOUND' ;
            IF PB$Raise THEN
              RAISE_APPLICATION_ERROR( -20100, LC$Msg ) ;
            END IF ;
            DBMS_OUTPUT.PUT_LINE(LC$Msg) ;
            RETURN ;      
        END  ;
     
        -- open the output file --
        LF$FicOUT := UTL_FILE.FOPEN( PC$Directory, PC$File_Name, 'W', 32764 ) ;
     
        -- write the file --
        LOOP
           -- read the chunks --
           Dbms_Lob.READ (src_lob, amt, pos, buffer);
           -- write the chunks --
             UTL_FILE.Put_Raw(LF$FicOut, buffer);
           pos := pos + amt;
        END LOOP;
        -- close the file --
        UTL_FILE.FCLOSE(LF$FicOut);
     
      EXCEPTION
        WHEN NO_DATA_FOUND THEN
            UTL_FILE.FCLOSE(LF$FicOut);
        WHEN OTHERS THEN
          LC$Msg := 'Write_Binary_File() Error : ' || TO_CHAR( SQLCODE ) || ' while managing file ('
           || PC$Directory || ') ' ||  PC$File_Name ;
          IF PB$Raise THEN
             RAISE_APPLICATION_ERROR( -20100, LC$Msg ) ;
          END IF ;
          DBMS_OUTPUT.PUT_LINE(LC$Msg);
      END Write_Binary_File;
    /

Discussions similaires

  1. [JDBC]ouvrir un fichier pdf à partir d'un blob
    Par souletis dans le forum JDBC
    Réponses: 5
    Dernier message: 25/01/2007, 22h03
  2. Pb de création de fichier à partir d'un blob
    Par clairette dans le forum Entrée/Sortie
    Réponses: 20
    Dernier message: 28/08/2006, 10h51
  3. Changer les attributs de fichier à partir de FrontPage
    Par kernel57 dans le forum Balisage (X)HTML et validation W3C
    Réponses: 7
    Dernier message: 26/01/2005, 16h44
  4. Exécuter un fichier à partir du code
    Par TheCool dans le forum ASP
    Réponses: 28
    Dernier message: 18/01/2005, 20h22
  5. [Servlet][EJB]lire un fichier à partir de mon bean
    Par kimausoleil dans le forum Servlets/JSP
    Réponses: 3
    Dernier message: 13/02/2004, 15h26

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