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

Langage PHP Discussion :

[Système] comment éviter un warning


Sujet :

Langage PHP

  1. #1
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 486
    Billets dans le blog
    1
    Par défaut [Système] comment éviter un warning
    Bonjour,

    je voudrais savoir si je peux (et ds ce cas, comment) éviter un warning qui se produit lorsque le type d'une variable passée à une fct n'est pas celui attendu ? Ds ce cas, la fct n'est pas appelée, mais l'erreur est qd même détectée.
    En fait, ayant un compte sur free avec une base de données, et trouvant que leur interface phpmyadmin est hyper lente, je me suis développé en php une interface me permettant d'envoyer des requêtes SQL. Ca marche, mais s'il n'y a aucun affichage, visiblement la variable retournée par la fct mysql_query n'est pas du type resource et l'appel à la fct mysql_fetch_array (qui n'est pas exécuté ds ce cas) génère qd même un warning. Y a-t-il moyen de l'éviter et, si oui, comment ?

  2. #2
    Expert confirmé
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 313
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 313
    Billets dans le blog
    17
    Par défaut
    Oui avec un if( ) testant la valeur retournée par mysql_query( ).
    => Si différent de FALSE alors tu peux utiliser mysql_fetch_*( ).

  3. #3
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 486
    Billets dans le blog
    1
    Par défaut
    J'ai déjà fait ça, mais visiblement, la seule présence de l'appel ds le code suffit à générer le warning...

  4. #4
    Expert confirmé
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 313
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 313
    Billets dans le blog
    17
    Par défaut
    Montre-nous la portion de code incriminée.

  5. #5
    Membre émérite
    Profil pro
    Inscrit en
    Août 2005
    Messages
    514
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2005
    Messages : 514
    Par défaut
    Bonjour,
    quelque chose comme ceci?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
      if (!$res = mysql_query($req)) exit(mysql_error());
     
      if ($res !== TRUE) echo mysql_num_rows($res).' ligne(s) retournee(s)';
      else echo 'La variable $res n\'est pas une ressource MySQL';
    Cordialement,
    DaRiaN.

  6. #6
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 486
    Billets dans le blog
    1
    Par défaut
    Voici le code qui pose pb :
    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
     
    if (!($result=mysql_query($sql))) echo "pb avec la requête"; else 
    {echo "requête OK";echo"<br>";
    echo $result; echo "<br>";
     
    if (((is_resource($result))) or (!($result==""))or (!($result=="1")))
    while ($ligne=mysql_fetch_array($result,MYSQL_NUM))
    {
    	$i=0;
    	while (((!($ligne[$i]==""))&&($i==0)) or ($i <= $max))
    	{
    	if ($i==0) $max=$i;
    	echo $ligne[$i++]." "; 
    	}
    }
    }
    J'y ai évidemment rajouté des tests inutiles.

  7. #7
    Membre émérite
    Profil pro
    Inscrit en
    Août 2005
    Messages
    514
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2005
    Messages : 514
    Par défaut
    Essayez avec celui-ci :

    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
    <?php
     
      $result = mysql_query($sql) or die(mysql_error());
     
      if ($result !== TRUE)
      { 
        while ($ligne = mysql_fetch_array($result, MYSQL_NUM))
        {	
          $i=0;
     
          while (((!($ligne[$i]=="")) && ($i==0)) or ($i <= $max))
          {
            if ($i==0) $max=$i;
            echo $ligne[$i++]." "; 
          }
        }
      }
     
    ?>
    PS: ce n'est pas pour critiquer, mais votre script est assez bizarre.

  8. #8
    Expert confirmé
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 313
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 313
    Billets dans le blog
    17
    Par défaut
    /!\ if ($result !== FALSE)

  9. #9
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 486
    Billets dans le blog
    1
    Par défaut
    Je viens de faire l'essai et ça marche. Je suis super content. Visiblement, ça vient de la fct die, mais que fait-elle exactement ? Et pourquoi ça marche maintenant ?
    Sinon, mon code est peut-être un peu bizarre, mais en fait, ne connaissant pas la longueur d'une ligne affichée, et pensant qu'une ligne pouvait contenir des "" (donc c'est une mauvaise condition d'arrêt d'affichage), je mesure la longueur de la 1e ligne, et ça constitue ma condition d'arrêt d'affichage pour les suivantes.
    En tout cas, merci.

  10. #10
    Membre émérite
    Profil pro
    Inscrit en
    Août 2005
    Messages
    514
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2005
    Messages : 514
    Par défaut
    Citation Envoyé par Séb. Voir le message
    /!\ if ($result !== FALSE)
    Vous êtes sûr?

  11. #11
    Expert confirmé
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 313
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 313
    Billets dans le blog
    17
    Par défaut
    Citation Envoyé par DaRiaN Voir le message
    Vous êtes sûr?
    Ben pour un SELECT mysql_query( ) retourne soit une ressource soit FALSE si la requête échoue, donc oui.

  12. #12
    Membre émérite
    Profil pro
    Inscrit en
    Août 2005
    Messages
    514
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2005
    Messages : 514
    Par défaut
    Citation Envoyé par http://fr.php.net/mysql_query

    Pour les requêtes du type SELECT, SHOW, DESCRIBE, EXPLAIN et les autres requêtes retournant un jeu de résultats, mysql_query() retournera une ressource en cas de succès, ou FALSE en cas d'erreur.

    Pour les autres types de requêtes, UPDATE, DELETE, DROP, etc., mysql_query() retourne TRUE en cas de succès ou FALSE en cas d'erreur.
    Si ce n'est pas FALSE ou TRUE alors c'est une ressource, d'où le !== TRUE.

  13. #13
    Rédacteur

    Avatar de Yogui
    Homme Profil pro
    Directeur technique
    Inscrit en
    Février 2004
    Messages
    13 721
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yonne (Bourgogne)

    Informations professionnelles :
    Activité : Directeur technique

    Informations forums :
    Inscription : Février 2004
    Messages : 13 721
    Par défaut
    Salut

    Si ton objectif est d'éviter un warning, tu as plusieurs options :
    • Gérer les erreurs (pas toujours suffisant) ;
    • Faire taire le warning en mettant '@' avant le nom de la fonction (très moche) ;
    • Et la meilleure solution : modifier la config display_errors à Off.

  14. #14
    Membre émérite
    Profil pro
    Inscrit en
    Août 2005
    Messages
    514
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2005
    Messages : 514
    Par défaut
    La cause du warning n'est plus, car !== TRUE vérifie que le résultat de mysql_query est une ressource, car si ce n'est pas FALSE ou strictement TRUE, alors c'est une ressource. Je n'aime pas masquer les warning, je préfère coder proprement mes scripts.

  15. #15
    Expert confirmé
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 313
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 313
    Billets dans le blog
    17
    Par défaut
    Citation Envoyé par DaRiaN Voir le message
    Si ce n'est pas FALSE ou TRUE alors c'est une ressource, d'où le !== TRUE.
    Bien sûr, mais je ne vois pas pourquoi tester TRUE car :
    - il n'est jamais retourné dans ce cas là
    - on cherche à exécuter le if( ) s'il n'y a pas d'erreurs, ce qui de prime abord n'est pas évident avec un test !== TRUE
    Bon on va dire que c'est une question d'habitude
    @+

  16. #16
    Membre émérite
    Profil pro
    Inscrit en
    Août 2005
    Messages
    514
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2005
    Messages : 514
    Par défaut
    LaurentSc semble utiliser toutes sortes de requête avec ce script et pas seulement des SELECT, la preuve en est : le warning en question.

    Voilà le pourquoi du !== TRUE maintenant si je me suis fourvoyé, cela ne gène en rien le script, par contre, dans le cas contraire, ça fait toute la différence.

  17. #17
    Membre Expert
    Avatar de ThomasR
    Homme Profil pro
    Directeur technique
    Inscrit en
    Décembre 2007
    Messages
    2 230
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur technique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Décembre 2007
    Messages : 2 230
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    @$result = mysql_query($sql);
    @ empêche l'affichage du warning

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

Discussions similaires

  1. Réponses: 8
    Dernier message: 18/08/2010, 18h56
  2. [xajax] comment éviter les warnings
    Par jaljal dans le forum Langage
    Réponses: 8
    Dernier message: 30/08/2009, 16h02
  3. Réponses: 2
    Dernier message: 08/09/2008, 16h56
  4. Réponses: 2
    Dernier message: 11/06/2008, 19h16
  5. Réponses: 6
    Dernier message: 06/06/2008, 14h09

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