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

Requêtes MySQL Discussion :

Distinct à l'intérieur d'un Group By ?


Sujet :

Requêtes MySQL

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    126
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 126
    Points : 55
    Points
    55
    Par défaut Distinct à l'intérieur d'un Group By ?
    Bonjour

    J'ai une table qui stocke des téléchargements de fichiers (un téléchargement = un enregistrement). Cette table enregistre 4 informations : l'id du téléchargement (AUTO INCREMENT), l'id du fichier téléchargé, la date du téléchargement et l'IP du téléchargeur :

    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
    CREATE TABLE IF NOT EXISTS `exp_dl` (
      `dl_id` int(11) NOT NULL AUTO_INCREMENT,
      `dl_item_id` int(11) DEFAULT NULL,
      `dl_date` date NOT NULL,
      `dl_ip` varchar(50) DEFAULT NULL,
      PRIMARY KEY (`dl_id`)
    ) ENGINE=MyISAM  DEFAULT CHARSET=latin1;
     
    INSERT INTO `exp_dl` (`dl_id`, `dl_item_id`, `dl_date`, `dl_ip`) VALUES
    (1,  7,  '2012-01-22', '127.0.0.1'),
     
    (2,  17, '2012-01-23', '127.0.0.1'),
     
    (3,  6,  '2012-01-24', '127.0.0.1'),
    (4,  9,  '2012-01-24', '192.168.1.2'),
    (5,  4,  '2012-01-24', '192.168.1.2'),
     
    (6,  10, '2012-01-25', '127.0.0.1'),
    (7,  5,  '2012-01-25', '127.0.0.1'),
    (8,  8,  '2012-01-25', '127.0.0.1'),
    (9,  24, '2012-01-25', '192.168.1.2'),
    (10, 14, '2012-01-25', '90.150.10.30'),
    (11, 17, '2012-01-25', '90.150.10.30');
    J'ai écrit une petite requête SQL qui me permet de voir le nombre total de téléchargements par jour :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    SELECT dl_date, COUNT(dl_id) AS nb_dl
    FROM exp_dl
    GROUP BY dl_date
     
    /*
    Resultat :
    dl_date      nb_dl
    2012-01-22   1
    2012-01-23   1
    2012-01-24   3
    2012-01-25   6
    */
    Jusque là tout va bien.

    Maintenant, j'aimerais écrire une seconde requête qui ignore les doublons sur le champ IP (le but étant d'avoir le nombre de téléchargeurs par jour, et pas le nombre de téléchargements par jour).

    Cette requête devrait retourner ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    /*
    Resultat :
    dl_date      nb_dl
    2012-01-22   1
    2012-01-23   1
    2012-01-24   2
    2012-01-25   3
    */
    Je ne vois pas comment faire pour "restreindre" le GROUP BY en fonction du champ IP, pour chaque date.

    Merci pour votre aide.

  2. #2
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    3 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    Bonjour,

    Ca n'est pas bien plus compliqué :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SELECT dl_date, COUNT(distinct dl_id) AS nb_dl
    FROM exp_dl
    GROUP BY dl_date

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    126
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 126
    Points : 55
    Points
    55
    Par défaut
    Bon OK je vais me cacher, rangez les tomates .

    Edit : c'est pas "COUNT(DISTINCT dl_id)" mais "COUNT(DISTINCT dl_ip)".

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 02/11/2011, 16h57
  2. [A-00] Count(Distinct) avec plusieurs Select et Group by...
    Par Thomak dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 30/10/2008, 11h11
  3. [Oracle] group by, decode, et distinct
    Par babylone7 dans le forum Langage SQL
    Réponses: 8
    Dernier message: 12/02/2007, 13h11
  4. Distinct, group by et order by
    Par gloubi dans le forum Langage SQL
    Réponses: 8
    Dernier message: 27/11/2006, 16h53
  5. Problème requête avec group by et distinct
    Par tomca dans le forum Langage SQL
    Réponses: 2
    Dernier message: 20/07/2005, 16h10

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