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 :

Select * ne donne pas de résultat [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre confirmé Avatar de restart
    Inscrit en
    Novembre 2009
    Messages
    84
    Détails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 84
    Par défaut Select * ne donne pas de résultat
    bonjour
    j'ai crée un code php permettant d'afficher les codes et les titres des livres d'une bibliothèque
    le code que j'ai crée est :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    $reponse=mysql_query("select * from livre");
     
    		while ($donnee=mysql_fetch_array($reponse))
    		{
    		 echo $donnee['code_livre'];
    		 echo $donnee['titre'];
    		 echo "<br/>";
     
    		}

    l'exécution du code précédant n'affiche rien sur la page php
    mais
    lorsque je remplace la requête appeler par la requête suivante :

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    select code_livre,titre from livre

    le code php fonctionne correctement et affiche les codes et les titres des livres de la table
    je voudrais savoir pourquoi la fonctionne * ne donne pas de résultat dans ce cas la
    merci

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Fait un
    dans ta boucle pour voir ce que tu recoltes precisemment.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre Expert Avatar de Fench
    Homme Profil pro
    Chercheur en informatique
    Inscrit en
    Mai 2002
    Messages
    2 353
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Groenland

    Informations professionnelles :
    Activité : Chercheur en informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Mai 2002
    Messages : 2 353
    Par défaut
    Salut,

    le mysql_fetch_array est par défaut un MYSQL_BOTH (voir manuel php) et,
    dans le cas d'un select *, il doit comprendre un retour avec un tableau numérique (d'ou rien comme affichage puisque tu utilises de l'associatif).

    Au contraire, dans le SELECT code_livre,titre FROM ..., il comprends un retour avec un tableau associatif et donc ça marche.

    Essayes le select * mais un 'mysql_fetch_array($response, MYSQL_ASSOC)' pour voir,

    Edit: Comme le dit Sabotage, fait un print_r et tu comprendras mieux

  4. #4
    Membre confirmé Avatar de restart
    Inscrit en
    Novembre 2009
    Messages
    84
    Détails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 84
    Par défaut
    Citation Envoyé par sabotage Voir le message
    Fait un
    dans ta boucle pour voir ce que tu recoltes precisemment.

    l'insertion de cette fonction dans la boucle affiche :
    les codes des livres (code_livre)
    les titres (titre)
    les themes (themes)
    les dates d'editions (date_edit)
    et les nombre des pages (nbpags)

    es ce que cela pourrais donner une explication du fete que la requete :
    ne donne pas un affichage du résultat demander stp ?

  5. #5
    Membre confirmé Avatar de restart
    Inscrit en
    Novembre 2009
    Messages
    84
    Détails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 84
    Par défaut
    Citation Envoyé par Fench Voir le message
    Salut,

    le mysql_fetch_array est par défaut un MYSQL_BOTH (voir manuel php) et,
    dans le cas d'un select *, il doit comprendre un retour avec un tableau numérique (d'ou rien comme affichage puisque tu utilises de l'associatif).

    Au contraire, dans le SELECT code_livre,titre FROM ..., il comprends un retour avec un tableau associatif et donc ça marche.

    Essayes le select * mais un 'mysql_fetch_array($response, MYSQL_ASSOC)' pour voir,

    Edit: Comme le dit Sabotage, fait un print_r et tu comprendras mieux
    j'ai essayé de mettre mysql_fetch_array($response, MYSQL_ASSOC)
    mais ca donne un message d'erreur lors de l'excussion

    Warning: mysql_fetch_array() [function.mysql-fetch-array]: The result type should be either MYSQL_NUM, MYSQL_ASSOC or MYSQL_BOTH. in C:\wamp\www\tests\accueil.php on line 43


    que cela veux dire svp
    en fête je ne comprend pas la différence entre un tableau numérique et un tableau associatif
    pouvez vous m'expliquer la différence entre ces deux types de tableau lors de l'affichage svp
    merci

  6. #6
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    Simple : les clés d'un tableau numérique sont des nombres (0, 1, 2...), celles d'un tableau associatif sont des chaines ('nom', 'code', ...)
    Par défaut mysql_fetch_array te renvoie les données en double, indexées à la fois par le numéro de la colonne et le nom de la colonne. Si tu ne veux que les clés associatives, tu peux utiliser mysql_fetch_assoc...
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  7. #7
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Ce qui ne colle pas c'est justement qu'il devrait recevoir les deux... donc je dirais que le nom des champs ne sont pas les bons (je ne sais plus si on peut recevoir autre chose que des minuscules dans le tableau).
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  8. #8
    Membre confirmé Avatar de restart
    Inscrit en
    Novembre 2009
    Messages
    84
    Détails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 84
    Par défaut
    Citation Envoyé par sabotage Voir le message
    Ce qui ne colle pas c'est justement qu'il devrait recevoir les deux...
    excuser moi
    mais je comprend pas ce que vous voulez dire par "recevoir les deux"


    Citation Envoyé par sabotage Voir le message
    donc je dirais que le nom des champs ne sont pas les bons (je ne sais plus si on peut recevoir autre chose que des minuscules dans le tableau).
    je suis sur que j'ai bien mis les nom des attributs
    la preuve c'est que la deusieme requete fonctionne correctement

  9. #9
    Membre Expert Avatar de Fench
    Homme Profil pro
    Chercheur en informatique
    Inscrit en
    Mai 2002
    Messages
    2 353
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Groenland

    Informations professionnelles :
    Activité : Chercheur en informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Mai 2002
    Messages : 2 353
    Par défaut
    mais je comprend pas ce que vous voulez dire par "recevoir les deux"
    Ce que te disait Celira: Un fetch_array donne par défaut un tableau indexé numériquement et associativement:
    cad $donnee[0], $donnee[1] etc
    et $donnee['code_livre'], $donnee['titre']etc

    C'est pour celà que tu peux préciser MYSQL_ASSOC pour n'obtenir qu'un tableau associatif: $donnee['code_livre'], $donnee['titre']etc

    Edit: pour revenir à la question: Pourquoi avec le SELECT * $donnee['titre'] ne marche pas ?

  10. #10
    Membre confirmé Avatar de restart
    Inscrit en
    Novembre 2009
    Messages
    84
    Détails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 84
    Par défaut
    Citation Envoyé par Fench Voir le message
    Ce que te disait Celira: Un fetch_array donne par défaut un tableau indexé numériquement et associativement:
    cad $donnee[0], $donnee[1] etc
    et $donnee['code_livre'], $donnee['titre']etc

    C'est pour celà que tu peux préciser MYSQL_ASSOC pour n'obtenir qu'un tableau associatif: $donnee['code_livre'], $donnee['titre']etc

    Edit: pour revenir à la question: Pourquoi avec le SELECT * $donnee['titre'] ne marche pas ?
    je ne sais pas si j'ai bien compris ce que vous voulez dire la
    mais si j'ai bien compris
    si l'insertion de la requete
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    select * from livre
    dans la fonction mysql_query a eux lieu
    l'affichage des donnée ne peux pas avoir lieu si on utilise la fonction mysql_fetch_array
    mais dans ce cas il faut utiliser la fonction mysql_fetch_assoc
    et le code valide devient donc
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    $reponse=mysql_query("select * from livre");
    		echo "<br/> <br/> <br/>";
    		//il suffit maintenant de faire une boucle pour lister les composant de la table :
    		while ($donnee=mysql_fetch_assoc($reponse))
    		{
     
    			 echo $donnee['code_livre'],$donnee['titre'],$donnee['themes'],$donnee['nbpages']; 
     
     
    			 echo "<br/>";
     
     
     
    		}


    si cela est ce que vous voulez dire
    cette méthaude aussi ne donne pas un resultat
    il y a rien d 'afficher sur la page

  11. #11
    Membre Expert Avatar de Fench
    Homme Profil pro
    Chercheur en informatique
    Inscrit en
    Mai 2002
    Messages
    2 353
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Groenland

    Informations professionnelles :
    Activité : Chercheur en informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Mai 2002
    Messages : 2 353
    Par défaut
    Donc:
    Qd tu modifies le * par le nom des champs, c ok

    Tu peux donner la définition de la table (à tous hasards),

    Sinon bein

  12. #12
    Membre confirmé Avatar de restart
    Inscrit en
    Novembre 2009
    Messages
    84
    Détails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 84
    Par défaut
    Citation Envoyé par Fench Voir le message
    Donc:
    Qd tu modifies le * par le nom des champs, c ok

    Tu peux donner la définition de la table (à tous hasards),

    Sinon bein
    tu veux dire donc que c'est impossible d'afficher les données de la table livre si on utilise la requête select *

  13. #13
    Membre Expert Avatar de Fench
    Homme Profil pro
    Chercheur en informatique
    Inscrit en
    Mai 2002
    Messages
    2 353
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Groenland

    Informations professionnelles :
    Activité : Chercheur en informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Mai 2002
    Messages : 2 353
    Par défaut
    Ma conclusion est que: (je souhaiterais un expert toutefois )

    Qd tu fais un SELECT *, le tableau associatif n'est pas remplie seulement le tableau indéxé (mais c bizzare qd meme ),
    Parcontre en faisant
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    $reponse=mysql_query("select * from livre");
     
    		while ($donnee=mysql_fetch_array($reponse))
    		{
    		 echo $donnee[0];
    		 echo $donnee[1];
    		 echo "<br/>";
     
    		}
    ça devrait donner les bons résultats

  14. #14
    Membre confirmé Avatar de restart
    Inscrit en
    Novembre 2009
    Messages
    84
    Détails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 84
    Par défaut
    ok
    on dirrait qu'on a plus le choix
    on cas ou tu trouves une solution plus performante fait moi un appel
    bonne journée

  15. #15
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    La solution de debugage, je te l'ai donné : il faut faire un print_r et voir ce qu'on recoit dans le tableau.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

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

Discussions similaires

  1. [If] Test de condition ne donne pas le résultat attendu
    Par Moktar19 dans le forum Débuter
    Réponses: 3
    Dernier message: 09/11/2008, 14h52
  2. Réponses: 5
    Dernier message: 22/06/2007, 21h03
  3. Réponses: 2
    Dernier message: 11/12/2006, 19h46
  4. Réponses: 5
    Dernier message: 03/11/2006, 13h23
  5. Concaténation ne donne pas le résultat attendu
    Par artotal dans le forum Langage
    Réponses: 4
    Dernier message: 12/05/2006, 01h37

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