Précédent   Forum des professionnels en informatique > Bases de données > MySQL > Requêtes
Requêtes Forum d'entraide sur les requêtes MySQL
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 25/01/2012, 15h34   #1
Membre à l'essai
 
Inscription : novembre 2006
Messages : 121
Détails du profil
Informations forums :
Inscription : novembre 2006
Messages : 121
Points : 22
Points : 22
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 :
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 :
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 :
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.
Galdon est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/01/2012, 15h36   #2
Expert Confirmé
 
Homme
Inscription : mai 2002
Messages : 1 669
Détails du profil
Informations personnelles :
Sexe : Homme
Âge : 29
Localisation : France, Rhône (Rhône Alpes)

Informations forums :
Inscription : mai 2002
Messages : 1 669
Points : 2 680
Points : 2 680
Bonjour,

Ca n'est pas bien plus compliqué :
Code :
1
2
3
4
 
SELECT dl_date, COUNT(DISTINCT dl_id) AS nb_dl
FROM exp_dl
GROUP BY dl_date
punkoff est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/01/2012, 17h20   #3
Membre à l'essai
 
Inscription : novembre 2006
Messages : 121
Détails du profil
Informations forums :
Inscription : novembre 2006
Messages : 121
Points : 22
Points : 22
Bon OK je vais me cacher, rangez les tomates .

Edit : c'est pas "COUNT(DISTINCT dl_id)" mais "COUNT(DISTINCT dl_ip)".
Galdon est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 00h42.


 
 
 
 
Partenaires

Hébergement Web