SQL > select count distinct group by ACCESS
gerarcyr
-
Hydatid Messages postés 4 Statut Membre -
Hydatid Messages postés 4 Statut Membre -
Bonjour,
j'ai un problème avec une requete SQL qui intégre un DISTINCT, un COUNT et un GROUP BY.
Voici les champs de ma db : URL, IP, DATE1
A chaque connexion, on enregistre donc l'IP, la date et l'URL.
En fait, je voudrais connaitre le nombre de visiteurs unique qu'il y a eu sur mon site chaque jour à une adresse précise.
ex:
lundi 1 => 22 visiteurs
mardi 2 => 12 visiteurs
mercredi 3 => 54 visiteurs
etc...
Voici la requete SQL qui ne fonctionne pas :
SELECT count(*) as nb
FROM (SELECT distinct ip, date1 as d1 FROM stats2008)
WHERE url='http://...'
GROUP BY date1
Merci de votre aide,
j'ai un problème avec une requete SQL qui intégre un DISTINCT, un COUNT et un GROUP BY.
Voici les champs de ma db : URL, IP, DATE1
A chaque connexion, on enregistre donc l'IP, la date et l'URL.
En fait, je voudrais connaitre le nombre de visiteurs unique qu'il y a eu sur mon site chaque jour à une adresse précise.
ex:
lundi 1 => 22 visiteurs
mardi 2 => 12 visiteurs
mercredi 3 => 54 visiteurs
etc...
Voici la requete SQL qui ne fonctionne pas :
SELECT count(*) as nb
FROM (SELECT distinct ip, date1 as d1 FROM stats2008)
WHERE url='http://...'
GROUP BY date1
Merci de votre aide,
A voir également:
- Select count distinct access
- Please select boot device ✓ - Forum Windows
- Please select boot device - Forum Matériel & Système
- Exemple base de données access à télécharger gratuit - Forum Access
- Access appdata - Guide
- Acer quick access - Forum logiciel systeme
7 réponses
oups erreur
SELECT count(*) as nb
FROM stats2008
WHERE (SELECT distinct ip, date1 as d1 FROM stats2008 WHERE url='http://...')
GROUP BY date1
SELECT count(*) as nb
FROM stats2008
WHERE (SELECT distinct ip, date1 as d1 FROM stats2008 WHERE url='http://...')
GROUP BY date1
Bonjour,
Voila pas mal de temps que je me suis frotté à SQL, mais à votre place je décomposerais cette requete pour vérifier que le select intégré fonctionne seul.
Ensuite si ça fonctionne, je relancerai la requete complete sans le group by.
Voilà ce n'est qu'une méthode...
Bon courage
Tenez moi au courant si ça a marché..ça fait toujours plaisir.
Voila pas mal de temps que je me suis frotté à SQL, mais à votre place je décomposerais cette requete pour vérifier que le select intégré fonctionne seul.
Ensuite si ça fonctionne, je relancerai la requete complete sans le group by.
Voilà ce n'est qu'une méthode...
Bon courage
Tenez moi au courant si ça a marché..ça fait toujours plaisir.
Le problème viens du FROM, ça saute au nez.
Il faut mettre un table et pas autre chose.
La manipulation est simple :
SELECT ip, date
FROM stats2008
WHERE url='http'
GROUP BY ip, date
Déjà cette requete te donne la liste de ceux qui ce sont connecter pour tel ou tel jour.
Maintenant, il faut que tu compte combien y en a .
Il faut mettre un table et pas autre chose.
La manipulation est simple :
SELECT ip, date
FROM stats2008
WHERE url='http'
GROUP BY ip, date
Déjà cette requete te donne la liste de ceux qui ce sont connecter pour tel ou tel jour.
Maintenant, il faut que tu compte combien y en a .
Et bien, voyons voir ...
Si c'est bien sur access, tu peux faire donc :
Enregistre une 1ière requete :
SELECT ip, date
FROM stats2008
WHERE url='http'
GROUP BY ip, date
Tu l'a nomme "requete1"
Puis tu fais une seconde requete :
SELECT count(ip)
FROM requete1
GROUP BY date
Et le tour est joué.
Si c'est bien sur access, tu peux faire donc :
Enregistre une 1ière requete :
SELECT ip, date
FROM stats2008
WHERE url='http'
GROUP BY ip, date
Tu l'a nomme "requete1"
Puis tu fais une seconde requete :
SELECT count(ip)
FROM requete1
GROUP BY date
Et le tour est joué.
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Bonjour,
Qu'est ce qui ne va pas exactement dans ta requête ?
Sinon, lorsque tu fais un GROUP BY, tu ne peux le faire que sur des champs que tu sélectionne via ta requête. Dans ton cas tu essai de faire un GROUP BY date1 alors que tu ne la sélectionne pas (SELECT count(*) as nb).
Je rajouterai donc ceci dans ta requête :
Par contre je ne sais plus comment se gère le disctinct donc je ne peux pas plus t'aider.
Qu'est ce qui ne va pas exactement dans ta requête ?
Sinon, lorsque tu fais un GROUP BY, tu ne peux le faire que sur des champs que tu sélectionne via ta requête. Dans ton cas tu essai de faire un GROUP BY date1 alors que tu ne la sélectionne pas (SELECT count(*) as nb).
Je rajouterai donc ceci dans ta requête :
SELECT DISTINCT date1, count(*) as total FROM (SELECT distinct ip, date1 FROM stats2008) WHERE url='http://...' GROUP BY date1
Par contre je ne sais plus comment se gère le disctinct donc je ne peux pas plus t'aider.
salut
SELECT count(*) as nb
FROM stats2008
WHERE (SELECT distinct ip, date1 as d1 FROM stats2008) and url='http://...'
GROUP BY date1
test ça
SELECT count(*) as nb
FROM stats2008
WHERE (SELECT distinct ip, date1 as d1 FROM stats2008) and url='http://...'
GROUP BY date1
test ça
Bonjour,
Dans l'exemple résolu vous traiter d'une requête avec une seule table et un seul groupe ! J'ai un problème plus complexe :
Dans une requête constituée de 3 tables ([xTP-Patient] ; [xTP-Facture] ; [xTP-DetailActes]) liée entre elles et groupée selon la "Date_facture", je voudrais pour chaque journée afficher (calculer) le nombre de personnes de sexe masculin (Titre = Mr) et celle de sexe féminin (Titre = Mme) et le nombre de Consultations (Acte=Consultation) et Controle (Acte=Controle)!
Je ne voudrais pas créer une requête analyse croisée car j'ai deux en-têtes de colonnes (Titre et Acte) à créer ce qui est impossible !
Le code suivant :
M'affiche pour chaque journée le nombre total des consultants (pour les colonnes 2, 3 et 4) et le nombre total des femmes de toutes la base de données, j'ai pas encore introduits les autres expressions (Mr, Consultation, Contrôle).
Comment dois-je faire merci
Dans l'exemple résolu vous traiter d'une requête avec une seule table et un seul groupe ! J'ai un problème plus complexe :
Dans une requête constituée de 3 tables ([xTP-Patient] ; [xTP-Facture] ; [xTP-DetailActes]) liée entre elles et groupée selon la "Date_facture", je voudrais pour chaque journée afficher (calculer) le nombre de personnes de sexe masculin (Titre = Mr) et celle de sexe féminin (Titre = Mme) et le nombre de Consultations (Acte=Consultation) et Controle (Acte=Controle)!
Je ne voudrais pas créer une requête analyse croisée car j'ai deux en-têtes de colonnes (Titre et Acte) à créer ce qui est impossible !
Le code suivant :
SELECT [xTP-Facture].date_facture, Count([xTP-Patient].Id) AS CompteDeId, Count([xTP-Patient].Titre) AS CompteDeTitre, Count([xTP-DetailActes].Acte3) AS CompteDeActe3, DCount("[id]","xtp-Patient","[titre] = 'Mme' ") AS Mme
FROM [xTP-Patient] INNER JOIN ([xTP-Facture] INNER JOIN [xTP-DetailActes] ON [xTP-Facture].n_facture = [xTP-DetailActes].N_fact) ON [xTP-Patient].Id = [xTP-Facture].Id
GROUP BY [xTP-Facture].date_facture;
M'affiche pour chaque journée le nombre total des consultants (pour les colonnes 2, 3 et 4) et le nombre total des femmes de toutes la base de données, j'ai pas encore introduits les autres expressions (Mr, Consultation, Contrôle).
Comment dois-je faire merci
Mais le pb est resolu.
Merci a tous pour vos reponse
Merci.