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 :

Renvoyer AVG et COUNT [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Septembre 2009
    Messages
    37
    Détails du profil
    Informations personnelles :
    Âge : 56
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 37
    Par défaut Renvoyer AVG et COUNT
    Bonsoir, encore une petite question toute simple dont je ne trouve pas la réponse.

    Je questionne une base depuis un site avec cette requête

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $sql="SELECT AVG(prix) FROM magasin_article ";
    ou

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $sql="SELECT COUNT(mail) FROM magasin_article ";
    Mais je ne sais pas comment faire apparaître le résultat du calcul en php sur le site

    J'ai essayer avec ça

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    <?php
    	include('connexion.php');
    	$sql="SELECT COUNT(mail) FROM magasin_article ";
    	$retour = mysql_query($sql);
    		echo $retour;
    	mysql_close ();
    ?>
    mais ça ne renvoi rien sur le site.
    Comment récupérer la valeur et l'afficher ??

  2. #2
    Expert confirmé

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Par défaut
    faut faire un mysql_fetch_* ...

  3. #3
    Membre émérite Avatar de sebhm
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2004
    Messages
    1 090
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Landes (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2004
    Messages : 1 090
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    <?php
        include('connexion.php');
        $sql="SELECT COUNT(mail) as nb FROM magasin_article ";
        $resultat = mysql_query($sql);
        $retour=mysql_fetch_array($resultat); 
        echo $retour["nb"];
        mysql_close ();
    ?>
    mysql_query ne renvoie pas le resultat de la requete (resultat qui peut etre plusieurs lignes)
    mais une ressource utilisable dans des fonctions comme mysql_fetch_array et ses soeurs qui permettent de parcourir les resultats

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Septembre 2009
    Messages
    37
    Détails du profil
    Informations personnelles :
    Âge : 56
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 37
    Par défaut
    Merci pour votre réponse à tout les deux, j'ai essayé avec msql_fetch_array mais cela ne donne toujours pas de résultat

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    <?php
    	include('connexion.php');
    	$sql="SELECT COUNT(mail) FROM magasin_client ";
    	$retour = mysql_query($sql);
    	$resultat = mysql_fetch_array($retour);
    	echo $resultat[6];
    	mysql_close ();
    ?>
    (la colonne mail est le 6ème colonne).

    Il ne s'affiche toujours rien.

    (Je précise que la table est remplie, il y a des mails dedans )

  5. #5
    Expert confirmé

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Par défaut
    fais un var_dump($resultat);

    t'as le mysql.trace_mode d'activé ?

    si tu fais COUNT t'as que une colonne...

  6. #6
    Membre averti
    Profil pro
    Inscrit en
    Septembre 2009
    Messages
    37
    Détails du profil
    Informations personnelles :
    Âge : 56
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 37
    Par défaut
    merci à vous deux pour votre aide, c'est moi qui n'ai pas tout compris

    Avec ce code ça affiche correctement le résultat :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    <?php
    	include('connexion.php');
    	$sql="SELECT COUNT(mail) FROM magasin_client ";
    	$retour = mysql_query($sql);
    	$resultat = mysql_fetch_array($retour);
    	echo $resultat[0];
    	mysql_close ();
    ?>
    Il fallait que je demande la colonne 0 dans l'affichage de mon tableau de retour !!

    Merci

  7. #7
    Membre émérite Avatar de sebhm
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2004
    Messages
    1 090
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Landes (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2004
    Messages : 1 090
    Par défaut
    en effet, l'indice à utiliser n'est pas celui de la table initiale mais celui du resultat de la requete.
    tu peux aussi utiliser le nom des colonnes retournées, c'est pour cela que j'avais mis "AS nb" dans le select et que j'utilisais "resultat["nb"]"

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

Discussions similaires

  1. Requête sql UPDATE comportant 1 SELECT + 1 AVG + 1 COUNT
    Par tomazawak dans le forum Langage SQL
    Réponses: 5
    Dernier message: 23/10/2009, 16h38
  2. AVG et COUNT cumulé
    Par EriCstoFF dans le forum Langage SQL
    Réponses: 2
    Dernier message: 07/07/2009, 09h26
  3. mélanger avg et count
    Par mdr_cedrick dans le forum Langage SQL
    Réponses: 5
    Dernier message: 09/10/2008, 16h57
  4. fonction: renvoyer résultat d'un count .. group by ?
    Par ctobini dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 26/09/2006, 14h21
  5. Réponses: 5
    Dernier message: 20/09/2005, 14h39

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