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

SQL Oracle Discussion :

BLOB Oracle : extraction du contenu vers un champ texte Oracle


Sujet :

SQL Oracle

  1. #1
    Membre à l'essai
    Inscrit en
    Juillet 2005
    Messages
    29
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 29
    Points : 11
    Points
    11
    Par défaut BLOB Oracle : extraction du contenu vers un champ texte Oracle
    Bonjour à tous,

    je suis en train d'essayer de récupérer le contenu d'un fichier txt stocké en base sous la forme d'un BLOB.

    J'arrive, sous TOAD, à extraire le fichier et à visualiser son contenu via notepad.

    Ces fichiers contiennent peu de données, une à deux phrases tout au plus, et je dois les transférer dans une autre table via une requête SQL.

    Quelqu'un saurait comment faire cela ? Comment récupérer en SQL le contenu du fichier txt / BLOB ?

    Merci d'avance.

    Fabien.

  2. #2
    Membre à l'essai
    Inscrit en
    Juillet 2005
    Messages
    29
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 29
    Points : 11
    Points
    11
    Par défaut
    Je précise, en SQL comme en php d'ailleurs.

    Je pense devoir lire le contenu, puis le stocké, puis le ré-injecter dans un champ texte.

    Mais comment, si certains ont des pistes, je suis preneur.

    Merci.

    Fabien.

  3. #3
    Membre à l'essai
    Inscrit en
    Juillet 2005
    Messages
    29
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 29
    Points : 11
    Points
    11
    Par défaut
    ...toujours personne pour m'aider ?

  4. #4
    Membre expert

    Profil pro
    Inscrit en
    Février 2006
    Messages
    3 437
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 3 437
    Points : 3 597
    Points
    3 597
    Par défaut
    Exemple:

    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
    dev001> select * from v$version;
     
    BANNER
    ----------------------------------------------------------------
    Oracle Database 10g Enterprise Edition Release 10.2.0.2.0 - Prod
    PL/SQL Release 10.2.0.2.0 - Production
    CORE    10.2.0.2.0      Production
    TNS for 32-bit Windows: Version 10.2.0.2.0 - Production
    NLSRTL Version 10.2.0.2.0 - Production
     
    dev001>
    dev001> drop table s;
     
    Table dropped.
     
    dev001> drop table t;
     
    Table dropped.
     
    dev001>
    dev001> create table s(si int, sb blob);
     
    Table created.
     
    dev001> create table t(ti int, tb blob);
     
    Table created.
     
    dev001>
    dev001> insert into s values(1, utl_raw.cast_to_raw('12345'));
     
    1 row created.
     
    dev001> commit;
     
    Commit complete.
     
    dev001> insert into t values(1, null);
     
    1 row created.
     
    dev001> update t set tb = (select sb from s where si = 1) where ti = 1;
     
    1 row updated.
     
    dev001>
    dev001> select ti, utl_raw.cast_to_varchar2(tb) as tb from t;
     
            TI
    ----------
    TB
    --------------------------------------------------------------------------------
     
             1
    12345
    Remarques:
    • pour stocker du texte il faut utiliser CLOB et non BLOB
    • si la taille du texte est inférieure à 4000 caractères, utilisez un VARCHAR2.

  5. #5
    Membre à l'essai
    Inscrit en
    Juillet 2005
    Messages
    29
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 29
    Points : 11
    Points
    11
    Par défaut
    Merci Pifor, je test cela.


    Fabien.

  6. #6
    Expert confirmé
    Avatar de laurentschneider
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2005
    Messages
    2 944
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2005
    Messages : 2 944
    Points : 4 926
    Points
    4 926
    Par défaut
    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
     
    SQL> def _sqlplus_release
    DEFINE _SQLPLUS_RELEASE = "1101000600" (CHAR)
    SQL> select version from v$instance;
     
    VERSION
    -----------------
    10.2.0.3.0
     
    SQL> create table t(xy blob);
     
    Table created.
     
    SQL> insert into t(xy) values ('41');
     
    1 row created.
     
    SQL> select xy from t;
     
    XY
    ------------------------------------------------
    41
     
    SQL> select utl_raw.cast_to_varchar2(xy) from t;
     
    UTL_RAW.CAST_TO_VARCHAR2(XY)
    ------------------------------------------------
    A
    tu peux effectivement employer UTL_RAW, mais seulement si ton champ a moins de 2000 caractères, sinon il te faut employer PL/SQL

  7. #7
    Expert confirmé
    Avatar de laurentschneider
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2005
    Messages
    2 944
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2005
    Messages : 2 944
    Points : 4 926
    Points
    4 926
    Par défaut
    pour les blob et php en faisant une recherche sur ce site je trouve

    http://beaussier.developpez.com/arti...hp/mysql/blob/

    bon, ça concerne mysql, mais j'espère que le code php te sera quand-même utile

  8. #8
    Membre à l'essai
    Inscrit en
    Juillet 2005
    Messages
    29
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 29
    Points : 11
    Points
    11
    Par défaut
    Je continu a travailler sur ces 2 pistes, merci a vous.

    Fabien.

  9. #9
    Membre à l'essai
    Inscrit en
    Juillet 2005
    Messages
    29
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 29
    Points : 11
    Points
    11
    Par défaut
    En utilisant utl_raw.cast_to_varchar2 en SQL, j'ai l'erreur suivante : utilisation interdite du type de données LONG


    mes données stockées ne sont pourtant que des .txt...

  10. #10
    Expert confirmé
    Avatar de laurentschneider
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2005
    Messages
    2 944
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2005
    Messages : 2 944
    Points : 4 926
    Points
    4 926
    Par défaut
    quelle est le datatype ? BLOB ou LONG?

  11. #11
    Membre à l'essai
    Inscrit en
    Juillet 2005
    Messages
    29
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 29
    Points : 11
    Points
    11
    Par défaut
    Datatype : LONG, contient un blob.

  12. #12
    Expert confirmé
    Avatar de laurentschneider
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2005
    Messages
    2 944
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2005
    Messages : 2 944
    Points : 4 926
    Points
    4 926
    Par défaut
    dans les types il y a

    LONG
    LONG RAW
    CLOB
    BLOB

    Si tu as un type LONG, alors tu peux le sélectionner avec
    SELECT tonlong FROM tatable

  13. #13
    Membre à l'essai
    Inscrit en
    Juillet 2005
    Messages
    29
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 29
    Points : 11
    Points
    11
    Par défaut
    Fonctionne pas, je passe par du php.

    Merci en tout cas.

Discussions similaires

  1. Extraction du contenu d'un champ texte
    Par jowelle dans le forum Servlets/JSP
    Réponses: 2
    Dernier message: 03/11/2011, 17h16
  2. Réponses: 4
    Dernier message: 07/01/2008, 18h15
  3. d'un select vers un champ text
    Par alexander dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 14/03/2005, 14h14
  4. Insérer le contenu d'un champ texte dans un JavaScript
    Par yoyot dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 17/02/2005, 14h12
  5. Recuperer le contenu d'un champs texte
    Par bouboussjunior dans le forum ASP
    Réponses: 4
    Dernier message: 29/09/2004, 14h16

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