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

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  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 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 ?

  4. #4
    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

  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 ?

+ 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