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 :

MySQL et condition sur le résultat retourné par une requête


Sujet :

C

  1. #1
    Membre régulier
    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2005
    Messages
    202
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Services à domicile

    Informations forums :
    Inscription : Septembre 2005
    Messages : 202
    Points : 124
    Points
    124
    Par défaut MySQL et condition sur le résultat retourné par une requête
    Bonjour,
    J'ai un petit soucis avec la fonction ci-sessous :

    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
     
    int verrifStatusPere(int ID_Job)
    {
        MYSQL *conn = db_connect();
        MYSQL_RES *result = NULL;
        MYSQL_ROW row = NULL;
        sprintf(query, "SELECT jp.Status FROM JobPlanif AS jp LEFT JOIN JobDep AS jd ON jd.ID_Dep = jp.ID_Job WHERE ID_Dep = %s", ID_Job);
        char query[255];
     
        mysql_query(conn, query);
        result = mysql_use_result(conn);
     
        while (row = mysql_fetch_row(result)) {
            if (row[0] != "COMPL") {
                logMessage(ID_Job, "Job en cours");
            } else {
                logMessage(ID_Job, "Job termine");
            }
        }
     
        mysql_free_result(result);
        mysql_close(conn);
     
        return 0;
    }
    La connexion est OK
    La requete retourne bien la valeur COMPL pour l'ID_Job donné en paramètre
    logMessage ne fait qu'envoyer dans une table MySQL le message donné en second paramètre
    et c'est là le problème, ça me retourne toujours "Job en cours" alors que ça devrait
    être "Job fini". Quand j'affiche le contenu de row[0] j'ai bien COMPL
    Me suis planté quelque part, mais ou ?
    (Je me suis mis au C depuis quelques jours, alors si vous voyez de grosses erreurs, toutes critiques sera la bienvenue )

    Merci
    Stéphane

  2. #2
    Invité(e)
    Invité(e)
    Par défaut
    Bonjour,

    En c, on ne compare pas les chaines de caractères comme on compare des entiers :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     if (row[0] != "COMPL") {
                logMessage(ID_Job, "Job en cours");
            } else {
                logMessage(ID_Job, "Job termine");
            }
    est à remplacer par
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     if (strncmp(row[0],"COMPL",5)) {
                logMessage(ID_Job, "Job en cours");
            } else {
                logMessage(ID_Job, "Job termine");
            }
    La FAQ explique ça ici.

  3. #3
    Membre régulier
    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2005
    Messages
    202
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Services à domicile

    Informations forums :
    Inscription : Septembre 2005
    Messages : 202
    Points : 124
    Points
    124
    Par défaut
    Grand merci à toi, je suis impardonnable...
    Je vais me lire la FAQ cette nuit alors

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

Discussions similaires

  1. [PDO] PDO : Insérer le résultat retourné par une requête dans un tableau
    Par Encephalopatie dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 17/01/2015, 15h22
  2. [ksh] Boucler sur des lignes retournées par une requête SQL
    Par Cj_Dal dans le forum Shell et commandes GNU
    Réponses: 9
    Dernier message: 10/01/2013, 17h24
  3. Réponses: 2
    Dernier message: 24/12/2007, 09h53
  4. Problème de résultat retourné par une procédure stockée
    Par Access Newbie dans le forum Access
    Réponses: 23
    Dernier message: 17/08/2006, 11h42
  5. PSQLException "Aucun résultat retourné par la requête&q
    Par BRAUKRIS dans le forum PostgreSQL
    Réponses: 3
    Dernier message: 15/09/2005, 20h55

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