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 :

[SQL] Count sur jointure


Sujet :

PHP & Base de données

  1. #1
    oim
    oim est déconnecté
    Membre confirmé
    Inscrit en
    Décembre 2003
    Messages
    118
    Détails du profil
    Informations forums :
    Inscription : Décembre 2003
    Messages : 118
    Par défaut [SQL] Count sur jointure
    Bonsoir j'ai un petit problème avec cette requéte : le problème sont les 2 counts si "bc." est vide alors "bb." fonctionne par contre si "bc" n'est pas vide lles 2 counts s'additionnent, vous auriez une idée ?

    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
    20
    21
    22
    23
    24
     
    	$result = sql_query("SELECT
    		ba.id_cat, ba.titre, 
    		COUNT(bb.id) as bug, 
    		COUNT(bc.id) as com 
    		FROM ".$NPDS_Prefix."bug_cate ba 
    		LEFT JOIN bug bb ON ba.id_cat=bb.id_cat 
    		LEFT JOIN bug_com bc ON ba.id_cat=bc.id_cat 
    		WHERE ba.cat_ligne='1' 
    		GROUP BY ba.id_cat 
    		ORDER BY ba.titre ASC");
     
    	while ($liste_news = mysql_fetch_array($result))
    	{
     
    		$liste_news['titre']=stripslashes($liste_news['titre']);
     
    		echo '<tr class="bug_deux">'
    		.'<td>&nbsp;&nbsp;&nbsp;&nbsp;<img src="modules/'.$ModPath.'/images/fle.gif" />&nbsp;&nbsp;<a href="'.$ThisFile.'&subop=fiche&id_cat='.$liste_news['id_cat'].'">'.aff_langue(''.$liste_news['titre'].'').'</a></td>'
    		.'<td align="center">'.$liste_news['bug'].'</td>'
    		.'<td align="center">'.$liste_news['com'].'</td>'
    		.'</tr>';
     
    	}
    Merci !

  2. #2
    Membre chevronné Avatar de fenkys
    Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    376
    Détails du profil
    Informations personnelles :
    Âge : 58
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Octobre 2007
    Messages : 376
    Par défaut
    Tu ne peux pas avoir 2 counts dans la meme requete select.

    Si tu reflechis un peu au fonctionnement du count, tu comprendras pourquoi :
    count compte des lignes retournées par la requête, après un eventuel regroupement, il travaille après retour des résultats. Les deux counts travaillent donc sur les mêmes lignes.

Discussions similaires

  1. [Doctrine] Count sur jointure
    Par Leward dans le forum ORM
    Réponses: 0
    Dernier message: 11/11/2011, 03h24
  2. [SQL] count() sur plusieurs tables
    Par philodido dans le forum Langage SQL
    Réponses: 21
    Dernier message: 14/10/2011, 10h56
  3. count(*) sur jointure
    Par macadam75 dans le forum SQL
    Réponses: 6
    Dernier message: 17/08/2010, 20h02
  4. [MySQL 4.1] Count sur jointure avec null
    Par Arnard dans le forum Requêtes
    Réponses: 6
    Dernier message: 16/07/2007, 09h38
  5. 2 Count() sur deux tables en jointures gauches
    Par Alexandre T dans le forum Langage SQL
    Réponses: 2
    Dernier message: 03/09/2003, 16h53

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