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 :

Compter le nombre d'actions différentes par utilisateur


Sujet :

Langage SQL

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2011
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2011
    Messages : 15
    Points : 25
    Points
    25
    Par défaut Compter le nombre d'actions différentes par utilisateur
    Bonjour,

    Dans une table de base, je dispose d'infos sur qui fait quoi et quand (timestamp, userID, action).
    Je voudrais compter le nombre d'actions différentes par utilisateur.
    Dans l'idée, passer de
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    | timestamp  |  userID  |  action  |
    +------------+----------+-----------+
    |      ?     |     1    | manger   |
    |      ?     |     2    | manger   |
    |      ?     |     1    | boire    |
    |      ?     |     1    | boire    |
    |      ?     |     1    | dormir   |
    |      ?     |     2    | dormir   |
    à ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    | userID |    action   |   count   |
    +--------+-------------+-----------+
    |     1    |  manger   |     1     |
    |     1    |  boire    |     2     |
    |     1    |  dormir   |     1     |
    |     2    |  manger   |     1     |
    |     2    |  dormir   |     1     |
    Merci d'avance

  2. #2
    Expert éminent sénior
    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 801
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 801
    Points : 34 063
    Points
    34 063
    Billets dans le blog
    14
    Par défaut
    Qu'avez-vous essayé comme requête ?
    Ce n'est vraiment pas difficile !
    Il faut grouper (GROUP BY) et compter (COUNT).

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2011
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2011
    Messages : 15
    Points : 25
    Points
    25
    Par défaut
    Le "Ce n'est vraiment pas difficile !" sonne vraiment condescendant... Mais aura au moins le mérite de m'avoir fait douter.
    Je ne suis pas super familier avec GROUP BY, j'ignorais que l'on pouvait avoir plus d'une colonne dans la clause.

    Bref, cas résolu

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT userID, action, count(action)
    FROM MyTable
    WHERE timestamp > '2015-03-11 00:00:00' 
    GROUP BY userID, action
    ORDER BY userID ASC;
    Merci.

  4. #4
    Expert éminent
    Avatar de StringBuilder
    Homme Profil pro
    Chef de projets
    Inscrit en
    Février 2010
    Messages
    4 170
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2010
    Messages : 4 170
    Points : 7 422
    Points
    7 422
    Billets dans le blog
    1
    Par défaut
    Votre requête ne fait pas ce que vous avez demandé.
    En effet, votre requête indique pour chaque utilisateur la liste des actions qu'il a effectué, et pour chacune, le nombre de fois !

    Ce que vous avez demandé, c'est ça :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SELECT userID, count(distinct action)
    FROM MyTable
    WHERE timestamp > '2015-03-11 00:00:00' 
    GROUP BY userID
    ORDER BY userID ASC;
    Pour chaque utilisateur, le nombre d'actions différentes qu'il a effectué.

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

Discussions similaires

  1. Compter le nombre d'octets téléchargés par l'utilisateur
    Par hachimuto dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 6
    Dernier message: 03/11/2008, 11h46
  2. Réponses: 28
    Dernier message: 11/10/2006, 23h36
  3. compter le nombre de cellules commencant par
    Par euskadi dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 28/06/2006, 14h36
  4. Réponses: 2
    Dernier message: 28/04/2006, 14h28
  5. Compter le nombre d'enreg retournés par un DBExtract
    Par Sylvain James dans le forum XMLRAD
    Réponses: 2
    Dernier message: 02/11/2004, 15h15

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