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 :

[Débutant] Extraction de données en CSV ?


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Mai 2003
    Messages
    921
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Consultant en Business Intelligence

    Informations forums :
    Inscription : Mai 2003
    Messages : 921
    Par défaut [Débutant] Extraction de données en CSV ?
    Bonjour à tous,

    voilà comme d'hab on me demande à moi ce que personne ne sait faire ici !!!

    J'ai une requête SQL à laquelle je dois passer un paramètre, puis insérer les données qui en ressortent au sein de 4 fichiers .csv. En effet, une des conditions de la clause where possède 4 valeurs (connues) possibles.

    Idée 1 : Faire boucler ma requête sur ces 4 valeurs et insérer les résultats dans un fichier csv ? Mais, ceci va m'obliger à exécuter 4 fois la même requête (à 1 détail prêt) !

    Idée 2 : Exécuter la requête sans la condition "changeante" et exécuter une 2e requête sur le résultat de la 1ère permettant d'appliquer uniquement la fameuse condition (au sein d'une boucle afin de passer les non moins fameuses 4 valeurs) ? C'est possible ça ?!


    Merci d'avance de me guider dans le droit chemin !?

  2. #2
    Expert éminent
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Par défaut
    tu peux aussi insérer le résultat dans une table temporaire avec une colonne qui spécifie le nom du fichier destination et ensuite spooler dans les fichiers ad hoc

  3. #3
    Membre éclairé
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Mai 2003
    Messages
    921
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Consultant en Business Intelligence

    Informations forums :
    Inscription : Mai 2003
    Messages : 921
    Par défaut
    Citation Envoyé par orafrance Voir le message
    tu peux aussi insérer le résultat dans une table temporaire avec une colonne qui spécifie le nom du fichier destination et ensuite spooler dans les fichiers ad hoc
    Ah oui super ...







    ... mais t'aurais pas un exemple ?!

  4. #4
    Expert éminent
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Par défaut
    INSERT AS SELECT et UTL_FILE ou SPOOL sont tes amis

  5. #5
    Membre éclairé
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Mai 2003
    Messages
    921
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Consultant en Business Intelligence

    Informations forums :
    Inscription : Mai 2003
    Messages : 921
    Par défaut
    Citation Envoyé par orafrance Voir le message
    INSERT AS SELECT et UTL_FILE ou SPOOL sont tes amis
    OK pour "INSERT AS SELECT" par contre je n'arrive pas à trouver d'exemples concernant un SPOOL fonctionnant au sein d'une boucle ?

    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
    var [4] = {1,2,3,6};
     
    Début boucle
    SPOOL mon_fichier_&var..csv
    -- L'entête
    select 'code;volet;code_2;code_3;date_semaine'
    from dual;
     
    -- La requête dont les résultats seront séparés par des ";" (CSV)
    select '03;' ||
           'V' || tmp.tatatatatata ||';'||
           SUBSTR(tmp.ryryryryryryryr, 1, 9) ||';'||
           tmp.ryryryryryryryryr ||';'||
           tmp.vbvbvbvbvbvbvbvbv
    FROM tmp_stats tmp
    WHERE tmp.azazazazazaza = &var;
     
    SPOOL OFF
    Fin Boucle
    END
    C'est beau nan ? C'est un algo PL/SQLien !

    Il me faut 4 fichiers de sortie. Il faudrait que je stocke les valeurs "1", "2", "3" et "6" dans une variable ("var") de type tableau (ou autre) et que je boucle jusqu'à la fin de ce tableau.

    Malheureusement, je n'ai pas la moindre idée de comment faire ça en SQL ?!!

  6. #6
    Expert éminent
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Par défaut
    utilise UTL_FILE

  7. #7
    McM
    McM est déconnecté
    Expert confirmé

    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Juillet 2003
    Messages
    4 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Juillet 2003
    Messages : 4 580
    Billets dans le blog
    4
    Par défaut
    C'est quoi la différence entre les requetes pour les différentes valeurs ?

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

Discussions similaires

  1. Extraction de donnée sur TALEND de MongoDB vers XML ou CSV
    Par djtrp dans le forum Développement de jobs
    Réponses: 0
    Dernier message: 24/03/2014, 15h41
  2. [2005] Extraction de données depuis un fichier CSV
    Par alaabed dans le forum SSIS
    Réponses: 3
    Dernier message: 22/04/2011, 14h07
  3. Extraction de données d'un fichier csv
    Par freyr dans le forum Shell et commandes GNU
    Réponses: 2
    Dernier message: 24/11/2010, 09h08
  4. Réponses: 6
    Dernier message: 05/05/2010, 10h18
  5. [débutant]extraction des données d'un fichier xml simple
    Par ekram dans le forum Format d'échange (XML, JSON...)
    Réponses: 3
    Dernier message: 14/03/2007, 12h24

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