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 :

C++ et SQL : soucis de requête


Sujet :

C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Profil pro
    Étudiant
    Inscrit en
    Juillet 2009
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2009
    Messages : 12
    Par défaut C++ et SQL : soucis de requête
    Bonjour tout le monde,

    Je suis nouveau sur le forum et je pense que ça va être l'ultime solution pour résoudre mon problème. Enfin je l'espère.

    Voila je suis en train de réaliser une mediathèque en C++, développé sous Code::blocks.

    Je plante sur une fonction de recherche par titre de disque dans laquelle je dois récupérer le titre à rechercher d'un cin.

    Voici la fonction :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    void ConnectionDisque::rechercher(const Disque &d){
        string titre;
        cout << "entrez le titre" << endl;
        cin >> titre;
        int err =  mysql_query(&connection, "SELECT * FROM disque, artiste WHERE id_artiste = artiste.id AND disque.titre =  '"+titre+"'");
        if(err != 0){
             throw SQLErrorException(mysql_error(&connection));
     
        // On recupere le resultat
        result = mysql_use_result(&connection);
        }
     
    }
    Et voici mon erreur générée :

    error: cannot convert `std::basic_string<char, std::char_traits<char>, std::allocator<char> >' to `const char*' for argument `2' to `int mysql_query(MYSQL*, const char*)'|
    Ceci est pour mon projet de fin d'année de master que je dois rendre dans 2 semaines...

    J'espère que vous pourrez faire quelque chose pour moi

    Merci d'avance

  2. #2
    Rédacteur
    Avatar de 3DArchi
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    7 634
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 7 634
    Par défaut
    Bonjour et bienvenu,
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    "SELECT * FROM disque, artiste WHERE id_artiste = artiste.id AND disque.titre =  '"+titre+"'"
    a comme résultat un std::string et il n'y a pas de conversion implicite vers const char*.
    Il faut que tu passes par une variable intermédiaire puis utilises c_str() :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    std::string requete = "SELECT * FROM disque, artiste WHERE id_artiste = artiste.id AND disque.titre =  '"+titre+"'";
    int err =  mysql_query(&connection, requete.c_str());

  3. #3
    Membre habitué
    Profil pro
    Étudiant
    Inscrit en
    Juillet 2009
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2009
    Messages : 12
    Par défaut
    Je te remercie je vais essayer, cependant pourrais-tu me dire ce que je fais de la ligne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     int err =  mysql_query(&connection, "SELECT * FROM disque, artiste WHERE id_artiste = artiste.id AND disque.titre =  '"+titre+"'");
    Je la remplace par :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    std::string requete = "SELECT * FROM disque, artiste WHERE id_artiste = artiste.id AND disque.titre =  '"+titre+"'";
    ?

    Merci d'avance

  4. #4
    Membre habitué
    Profil pro
    Étudiant
    Inscrit en
    Juillet 2009
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2009
    Messages : 12
    Par défaut
    Bon tout se compile tres bien mais maintenant quand j'éxécute il me balance une erreur de mémoire :

    L'instruction à "0x100052a6" emploie l'adresse memoire "0x0000000c". La mémoire ne peut pas être "read"

    Une idée ?

  5. #5
    Membre habitué
    Profil pro
    Étudiant
    Inscrit en
    Juillet 2009
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2009
    Messages : 12
    Par défaut
    Apres avoir lancé le debugger, j'ai trouvé d'ou venait le bug.

    Voici ce que le debugger me dit :

    100052A6 mysql_fetch_row()
    004023EB ConncetionDisque::get_next_disque(this=0x22fba0)
    0040429d main()
    Voici ma fonction get_next_disque() :

    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
    Disque ConnectionDisque::get_next_disque(){
        MYSQL_ROW row;
        if(row = mysql_fetch_row(result)){
            return
            (Disque(atoi(row[0]), /* Id */
            row[1], /* Titre */
            atoi(row[2]),/* Année */
            Artiste (atoi(row[4]), /* Id Artiste (Table Artiste) */
            row[5], /* Nom */
            row[6]))); /* Prénom */
        }
        else{
            throw NoMoreRowException();
        }
    }
    Voici son appel dans le main() :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    try{
                            Disque d;
                            //conn.effectuer_requete();
                            conn.rechercher(d);
                            //while(true){
                            d = conn.get_next_disque();
                            d.afficher();
                        //}
                    }
                    catch(NoMoreRowException &e){
                }

  6. #6
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 395
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    Au passage, ce code est la porte ouverte vers de l'injection SQL (si on ignore le fait que cin >> titre s'arrêtera au premier espace venu, car il paraît intentionnel).

    Utiliser des paramètres SQL ou bien mysql_escape_string().
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

Discussions similaires

  1. [SQL] Soucis dans une requête
    Par biddal dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 20/02/2008, 14h27
  2. [SQL] Soucis à l'update d'une requête
    Par Him dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 03/12/2007, 19h13
  3. [SQL] Soucis requête SQl sur serveur Free
    Par Ryuuku dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 30/08/2007, 16h20
  4. [SQL] Soucis avec une requête
    Par Auden dans le forum PHP & Base de données
    Réponses: 9
    Dernier message: 31/05/2007, 15h07
  5. [SQL] Soucis d'affichage de requête SQL
    Par kilkikou dans le forum PHP & Base de données
    Réponses: 9
    Dernier message: 06/06/2006, 16h25

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