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

PHP & Base de données Discussion :

Tester si une requête renvoie ou non des résultats [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre à l'essai
    Inscrit en
    Janvier 2006
    Messages
    12
    Détails du profil
    Informations forums :
    Inscription : Janvier 2006
    Messages : 12
    Points : 12
    Points
    12
    Par défaut Tester si une requête renvoie ou non des résultats
    Bonsoir,

    j'exécute :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     $SQL=mysql_query("SELECT a FROM table WHERE ...")
     $row=mysql_fetch_row($SQL);
     $a=$row[0];
    sauf que l'enregistrement recherché n'existe pas, alors $a n'a aucune valeur parce que la requête $SQL n'a renvoyé aucune valeur. Donc, voici ma question: comment faire un test via php du genre
    si $SQL ne renvoi aucune valeur alors $b=valeur1; sinon $b=$a;

    Sinon auriez-vous une idée à me proposer. Merci

  2. #2
    Expert éminent sénior

    Profil pro
    Inscrit en
    Juin 2002
    Messages
    6 152
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 6 152
    Points : 17 777
    Points
    17 777
    Par défaut
    Les fonctions mysql_fetch_* revoient FALSE s'il n'y a pas ou plus de résultats :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    $SQL=mysql_query("SELECT a FROM table WHERE ...")
    $row=mysql_fetch_row($SQL);
    if ($row === FALSE) {
        $b = $a;
    } else {
        $b = $row[0];
    }
    Une autre solution est de regarder combien de résultats sont renvoyés en tout à l'aide de la fonction mysql_num_rows :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    $SQL=mysql_query("SELECT a FROM table WHERE ...")
    if (mysql_num_rows($SQL) > 0) {
        /* Pour garder votre code */
        $row=mysql_fetch_row($SQL);
        $b = $row[0];
    } else {
        $b = $a;
    }

  3. #3
    Membre à l'essai
    Inscrit en
    Janvier 2006
    Messages
    12
    Détails du profil
    Informations forums :
    Inscription : Janvier 2006
    Messages : 12
    Points : 12
    Points
    12
    Par défaut
    super ! Merci julp

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

Discussions similaires

  1. Tester si une requête retourne des résultats
    Par nono27200 dans le forum Sql*Plus
    Réponses: 1
    Dernier message: 10/11/2008, 21h32
  2. Savoir si une requète renvoie une valeur ou non
    Par Pioul dans le forum VBA Access
    Réponses: 4
    Dernier message: 20/05/2008, 14h12
  3. [MySQL] Tester si la requête renvoie ou non des résultats
    Par khalidlyon dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 17/03/2008, 21h00
  4. [MySQL] Savoir si une requête renvoie des résultats
    Par Sytchev3 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 25/10/2007, 14h53
  5. Tester si une requête renvoie un résultat
    Par dl_jarod dans le forum ASP
    Réponses: 4
    Dernier message: 13/10/2005, 15h48

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