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 SQL Discussion :

Problème de requête MIN + COUNT


Sujet :

Langage SQL

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juin 2011
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2011
    Messages : 11
    Points : 6
    Points
    6
    Par défaut Problème de requête MIN + COUNT
    Bonjour,

    je suis en train de m'arracher les cheveux sur une requête SQL. J'ai deux tables, une table CAMPAGNE et une table MEMBRES. Je souhaite récupérer l'id de la campagne ayant le moins de membres.

    La table campagne dispose de l'id campagne ainsi que de son libele et d'autre caractéristiques.
    La table membre dispose quand à elle de l'id_campagne ( clef étrangère ).

    Je n'arrive pas à récupérer le résultat du COUNT(*) pour le réintégrer dans le MIN.

    Un petit peu d'aide serait fort sympathique.

  2. #2
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juin 2011
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2011
    Messages : 11
    Points : 6
    Points
    6
    Par défaut
    ci-joint les structure des deux tables concernées.

    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
    CREATE TABLE IF NOT EXISTS `campagne` (
      `id_campagne` int(11) NOT NULL AUTO_INCREMENT,
      `lbl_campagne` varchar(40) NOT NULL,
      `nb_max_users` int(11) NOT NULL,
      `type` int(11) NOT NULL,
      PRIMARY KEY (`id_campagne`)
    ) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=4 ;
     
    CREATE TABLE IF NOT EXISTS `membres` (
      `id` int(11) NOT NULL AUTO_INCREMENT,
      `id_campagne` int(11) NOT NULL DEFAULT '0',
      `login` varchar(20) NOT NULL,
      `password` varchar(90) NOT NULL,
       ................................................
      PRIMARY KEY (`id`)
    ) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=15 ;

  3. #3
    Membre averti
    Homme Profil pro
    Consultant PLM
    Inscrit en
    Août 2007
    Messages
    203
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Consultant PLM

    Informations forums :
    Inscription : Août 2007
    Messages : 203
    Points : 304
    Points
    304
    Par défaut
    Personnellement je créerai une vue associée à la comptabilisation du nombre de membres par campagne, et je requêterai sur cette vue.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    CREATE VIEW V_NB_MEMBRES_PAR_CAMPAGNE AS
    SELECT c.id_campagne AS id_campagne, COUNT(DISTINCT m.id) AS nb_membres
    FROM campagne c
    LEFT JOIN membres m ON c.id_campagne = m.id_campagne
    GROUP BY c.id_campagne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT id_campagne FROM V_NB_MEMBRES_PAR_CAMPAGNE
    WHERE nb_membres = (SELECT MIN(nb_membres) FROM V_NB_MEMBRES_PAR_CAMPAGNE)

  4. #4
    Expert éminent sénior
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 198
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 5 198
    Points : 12 774
    Points
    12 774
    Par défaut
    Bonjour,
    Avec MySql tu peux aussi utiliser LIMIT pour ne renvoyer qu'une seule ligne:
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SELECT c.id_campagne AS id_campagne, COUNT(DISTINCT m.id) AS nb_membres
    FROM campagne c
    LEFT JOIN membres m ON c.id_campagne = m.id_campagne
    GROUP BY c.id_campagne
    order by 2 LIMIT 1

    Par contre je ne suis pas très sûr de moi concernant la syntaxe de LIMIT

    Tatayo

  5. #5
    Membre expérimenté
    Avatar de islamov2000
    Homme Profil pro
    Ingénieur d'études & developpement en informatique
    Inscrit en
    Septembre 2007
    Messages
    814
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Ingénieur d'études & developpement en informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2007
    Messages : 814
    Points : 1 717
    Points
    1 717
    Billets dans le blog
    6
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    SELECT c.id_campagne, Count(m.id) AS Compte_id
    FROMcampagne c LEFT JOIN membres m ON c.id_campagne = m.id_campagne
    GROUP BY c.id_campagne
    having Count(m.id) =(select min(Compte_id)
                                   from (SELECT E_MVT.ste, Countm.id) AS Compte_id
                                             FROM campagne c LEFT JOIN membres m ON
                                                      c.id_campagne = m.id_campagne
                                        GROUP BY c.id_campagne)
                                 )
    d'avoir Pensé à voter positivement pour ceux qui vous ont aidés et surtout à mettre si le cas.
    ça encourage.

Discussions similaires

  1. Réponses: 9
    Dernier message: 20/08/2012, 22h44
  2. problème de requête avec utilisation de min/group by
    Par htristra dans le forum PostgreSQL
    Réponses: 0
    Dernier message: 02/10/2007, 13h16
  3. Problème de requête SQL avec DISTINCT et COUNT ?
    Par [ZiP] dans le forum Langage SQL
    Réponses: 4
    Dernier message: 29/01/2007, 17h11
  4. Problème de requête count(*) avec DB2
    Par elsodiop dans le forum DB2
    Réponses: 3
    Dernier message: 30/11/2006, 16h11
  5. Problème dans requête avec count()
    Par BadFox dans le forum Requêtes
    Réponses: 3
    Dernier message: 08/07/2003, 18h02

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