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 :

Manipulation Base de données C++


Sujet :

C++

  1. #1
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    1
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 1
    Points : 1
    Points
    1
    Par défaut Manipulation Base de données C++
    Bonjour,
    Dans le cadre de mes études, j'ai pour objectif de créer un programme c++ me permettant d'ajouter/supprimer/visualiser des informations dans ma base de données Access. J'ai réussi à me connecter sur celle-çi et à afficher diverses informations des tables mais je n'arrive pas a ajouter des informations dans les champs. J'ai tenté le coups avec avec des requètes SQL du style:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    char szSql[256] = "INSERT INTO PROFESSEUR(Prof-Pre, Prof-Nom) VALUES ('Tata', 'Toto')";
    Mais l'ordre SQL n'arrive pas a etre compilé.

    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
    66
    67
    68
    69
    70
     
    Voici mon code:
    #include <stdio.h>
    #include <stdlib.h>
    #include <windows.h>
    #include <sql.h>
    #include <sqlext.h>
    #include<conio.h>
     
     
    #pragma comment(lib, "odbc32.lib")
     
    int main(int argc, char *argv[])
    {
    //variables base de données
        static SQLHANDLE  hEnv;		//pointeur sur un environnement
        static SQLHANDLE  hDbc;		//pointeur sur une connexion
     
     
        int iOut;
        char strOut[256];
        //acces a la base de donnée
        char szDSN[256] = "driver={Microsoft Access Driver (*.mdb)};dbq=C:\\Users\\Alessandro\\Desktop\\ProG\\Machine Outil1.mdb";
        //ordres SQL
        char szSql[256] = "SELECT * FROM PROFESSEUR";	
     
     
        int ret1;
        int ret2;
        int ID;
        char Name[128];
     
     // 1 - Connexion a la BDD Access
        SQLAllocEnv(&hEnv);
        SQLAllocConnect(hEnv, &hDbc);
        if((SQLDriverConnect(hDbc, NULL, (unsigned char*)szDSN, SQL_NTS, (unsigned char*)strOut, 255, (SQLSMALLINT*)&iOut, SQL_DRIVER_NOPROMPT))==SQL_SUCCESS)
    		printf("Connecte\n");
     
        // 2 - Preparation de la requete
    HSTMT hStmt;//pointeur d'instruction ODBC.
    		if(SQLAllocHandle(SQL_HANDLE_STMT,hDbc,&hStmt)==SQL_SUCCESS)
    			printf("OK2\n");
    if (SQLPrepare(hStmt, (unsigned char*)szSql, SQL_NTS)==SQL_SUCCESS)//Prépare l'ordre Sql 
    			printf("Ordre Sql compile\n");
     
    // 3 - Execution de la requete
     
    SQLBindCol(hStmt, 1,SQL_C_ULONG,&ID,4,(SQLINTEGER*)&ret1);
    SQLBindCol(hStmt,2,SQL_C_CHAR,Name,128,(SQLINTEGER*)&ret2);
     
    		SQLExecute(hStmt);
     
        // 4 - Boucle pour afficher les resultats
        while(!(SQLFetch(hStmt) & 0xFFFE))
        {
            printf("{%i}{%s}\n",ID,Name);
        }
     
     
     
    	// 5 - Liberations et fermeture de la connection a la BDD
        SQLFreeStmt(hStmt, SQL_DROP);
        SQLDisconnect(hDbc);
        SQLFreeEnv(hEnv);
     
        getch();
     
     
    return 1;
    }
    Merci de votre aide.

  2. #2
    Membre éprouvé
    Profil pro
    Inscrit en
    Mai 2006
    Messages
    780
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Mai 2006
    Messages : 780
    Points : 1 176
    Points
    1 176
    Par défaut
    J'ai une (mauvaise?) nouvelle pour toi, tu ne fais pas de C++

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Février 2005
    Messages
    130
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 130
    Points : 115
    Points
    115
    Par défaut
    1°) Je pense que ce que veut dire Nikko, c'est qu'en C++, et dans tout autre langage Objet, normalement on utilise: des objets.
    => essaie de regrouper ton code en objets, tu vas voir c'est assez sympa à faire.
    Va faire un tour par là: http://general.developpez.com/cours/
    et plus particulièrement:
    http://www.developpez.biz/download/introobj.pdf
    ou
    ftp://ftp2.developpez.biz/developpo/...s/objetcpp.zip

    2°) Tu as une erreur qui s'affiche quelque part ?

  4. #4
    Membre éprouvé
    Profil pro
    Inscrit en
    Mai 2006
    Messages
    780
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Mai 2006
    Messages : 780
    Points : 1 176
    Points
    1 176
    Par défaut
    Citation Envoyé par Reeter Voir le message
    1°) Je pense que ce que veut dire Nikko, c'est qu'en C++, et dans tout autre langage Objet, normalement on utilise: des objets.
    euh ce que je veux dire, c'est qu'il utilise du C, de l'api windows et une librairie C pour la partie base de donnée, sans jamais faire de C++.

    Le grand problème du C++ étant que beaucoup de débutant n'arrivent pas à faire la différence avec du C (ce sont deux langages différents ), il vaut mieux je pense bien préciser pour les débutants qui traineraient sur le forum ou tomberaient sur ces pages suites à une recherche ce qui fait vraiment parti de ce forum et ce qui devrait être ailleurs.

    voilà, c'est toujours pareil, espérons que ça a ouvert les yeux de quelques débutants un jour.

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Février 2005
    Messages
    130
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 130
    Points : 115
    Points
    115
    Par défaut
    En effet, tu as complètement raison. Je voulais juste adoucir ton propos :-)

Discussions similaires

  1. VS express 2008 : manipulation base de données
    Par Irzin dans le forum Visual Studio
    Réponses: 0
    Dernier message: 14/08/2011, 19h51
  2. manipuler base de données Image en java
    Par amnass dans le forum JDBC
    Réponses: 1
    Dernier message: 15/06/2009, 12h28
  3. [LabWindows CVI] Manipulation base de données Access
    Par Beralienne dans le forum LabVIEW
    Réponses: 0
    Dernier message: 29/04/2009, 10h30
  4. Manipulation base de données
    Par intel_mark dans le forum SAS Base
    Réponses: 2
    Dernier message: 13/01/2009, 20h38

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