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

C Discussion :

generer un fichier via sql et C


Sujet :

C

Vue hybride

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 31
    Par défaut generer un fichier via sql et C
    Bonjour,

    je suis débutant en C, je dois faire un programme qui doit mettre le resultat d'une requête sql (oracle, ex select*from matable) dans un fichier texte.

    je sais que en SQL, il y a spool (pour créer le fichier), mais la base est sur une machine unix distante et je ne suis pas arrivé a lui spécifier un chemin.

    J'ai vu sur le forum qu'il y avait la fonction fopen, mais je ne vois pas comment, en utilisant cette fonction, lui dire "la requête que tu viens d'exécuter tu la mets dans le .txt"

    Merci de m'éclaircir sur ce point

  2. #2
    Modérateur
    Avatar de Obsidian
    Homme Profil pro
    Chercheur d'emploi
    Inscrit en
    Septembre 2007
    Messages
    7 476
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Chercheur d'emploi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2007
    Messages : 7 476
    Par défaut
    Citation Envoyé par gdeon Voir le message
    J'ai vu sur le forum qu'il y avait la fonction fopen, mais je ne vois pas comment, en utilisant cette fonction, lui dire "la requête que tu viens d'exécuter tu la mets dans le .txt"

    Merci de m'éclaircir sur ce point
    En C, tu travailleras à plus bas niveau. C'est-à-dire que c'est toi qui va mettre le contenu de ta requête dans ton fichier. Cependant, écrire des données dans un fichier se fait exactement de la même façon que sur l'écran (ou plus précisément, sur la sortie standard).

    Je ne connais pas par cœur l'API Oracle (moi j'utilisais Sybase et PostGreSQL au boulot), mais il y a deux manières de procéder en C : Soit tu utilises l'Embedded C SQL standard, c'est-à-dire l'espèce de langage de macros insérées dans ton code source (les trucs style « EXEC SQL SELECT ... » ), soit tu utilises directement l'API cliente du serveur que tu utilises.

    Ensuite, globalement, il faudra ouvrir la connexion, exécuter une requête, et en obtenir le résultat ligne par ligne, dans une boucle, puis refermer le tout. Dès lors, chaque fois que tu obtiens une ligne, tu peux l'écrire dans la foulée dans ton fichier.

  3. #3
    Expert confirmé
    Avatar de Melem
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2006
    Messages
    3 656
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Janvier 2006
    Messages : 3 656
    Par défaut
    Il existe également l'API ODBC qui permet de s'interfacer avec pratiquement tous les SGBD du marché (Oracle, Sybase, PostGreSQL, etc.).

    gdeon : tu te connectes à la base de données (ODBC), tu lances une requête (ODBC), tu récupères les résultat (ODBC) puis tu les écris dans un fichier (fopen, fprintf, fclose).

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    31
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 31
    Par défaut
    merci de os indication, ça m'a permis de comprendre certaine fonctions en C

  5. #5
    Rédacteur
    Avatar de Vincent Rogier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    2 373
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 2 373
    Par défaut
    Si tu bosses sous unix, passer par unixodbc ou iodbc avec oracle, tu vas t'amuser...

    Si ton prog ne doit attaquer que de l'oracle, utiliser OCILIB sera encore plus simple... et portable !

    Exemple complet en 30 lignes pour ta problématique (sans gestion des erreurs...) :

    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
     
    #include "ocilib.h"
     
    int main(void)
    {
        OCI_Connection *cn;
        OCI_Statement  *st;
        OCI_Resultset  *rs;
     
        if (!OCI_Initialize(NULL, NULL, OCI_ENV_DEFAULT))
            return EXIT_FAILURE;
     
        cn  = OCI_ConnectionCreate("db", "usr", "pwd", OCI_SESSION_DEFAULT);
        st  = OCI_StatementCreate(cn);
        f   = fopen("myfile.lst", "w");
     
        OCI_ExecuteStmt(st, "select field1, field2 from table1");
     
        rs = OCI_GetResultset(st);
     
        while (OCI_FetchNext(rs))
            printf("%s;%s\n", OCI_GetString(rs, 1), OCI_GetString(rs, 2));
     
        fclose(f);
     
        OCI_Cleanup();
     
        return EXIT_SUCCESS;
    }
    Vincent Rogier.

    Rubrique ORACLE : Accueil - Forum - Tutoriels - FAQ - Livres - Blog

    Vous voulez contribuer à la rubrique Oracle ? Contactez la rubrique !

    OCILIB (C Driver for Oracle)

    Librairie C Open Source multi-plateformes pour accéder et manipuler des bases de données Oracle

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

Discussions similaires

  1. [2008R2] Copie de fichier via SQL Server Agent
    Par stefano dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 19/03/2015, 16h21
  2. Modifier le nom d'une table d'un fichier Access via SQL
    Par benleq dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 23/07/2012, 16h03
  3. Réponses: 3
    Dernier message: 15/03/2009, 00h02
  4. [OpenOffice][Base de données] generer un fichier sql a partir d open office
    Par tesnimeronsard dans le forum OpenOffice & LibreOffice
    Réponses: 0
    Dernier message: 18/02/2008, 20h19
  5. Generer du xml via SQL(oracle) avec de l'asp
    Par jpg dans le forum XQUERY/SGBD
    Réponses: 6
    Dernier message: 03/08/2004, 12h36

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