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 :

Faire une somme sur les dernières valeurs saisies par chaque utilisateur


Sujet :

Langage SQL

  1. #1
    Membre régulier
    Inscrit en
    Mai 2002
    Messages
    190
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 190
    Points : 83
    Points
    83
    Par défaut Faire une somme sur les dernières valeurs saisies par chaque utilisateur
    Bonjour,

    Imaginez que j'ai la table suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    +------+---------------+-------------+--------------+
    | ID   | Utilisateur   | Estimation  | Date         |
    +------+---------------+-------------+--------------+
    | 9    | Jean          | 12          | 7 mai        |
    | 8    | Pierre        | 15          | 10 mai       |
    | 7    | Céline        | 0           | 7 mai        |
    | 6    | Céline        | 3           | 6 mai        |
    | 5    | Pierre        | 5           | 8 mai        |
    | 4    | Jean          | 10          | 6 mai        |
    | 3    | Jean          | 12          | 5 mai        |
    | 2    | Céline        | 4           | 28 avil      |
    | 1    | Jean          | 14          | 4 mai        |
    +------+---------------+-------------+--------------+
    La dernière estimation de Jean est : 12 (le 7 mai)
    La dernière estimation de Pierre est : 15 (le 10 mai)
    La dernière estimation de Céline est : 0 (le 7 mai)

    Je n'arrive pas à écrire une requette qui me donnerai la somme des dernières estimation ? cad. 12+15+0 = 27

    Pourriez-vous m'aider svp ?

    Merci

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 286
    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 286
    Points : 12 991
    Points
    12 991
    Par défaut
    Bonjour,
    Il faut commencer par chercher la dernière ligne pour chaque utilisateur.
    C'est une question très récurrente, donc une petite recherche te permettra de trouver comment faire.

    Une fois que tu as ces lignes, faire la somme devient trivial.

    Tatayo.

  3. #3
    Membre régulier
    Inscrit en
    Mai 2002
    Messages
    190
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 190
    Points : 83
    Points
    83
    Par défaut
    Bonjour,

    Tout d'abord, merci d'avoir pris le temps de répondre à ma question

    Pour m'en sortir, j'ai du accepter d'ajouter une colonne d'ID auto-incrémental (dans la réalité, je l'avais déjà ; mais je ne l'avais pas intégré dans ma table exemple). Et puisque les estimations des utilisateurs sont saisies avec des dates croissantes tout comme l'ID de chaque enregistrement, j'ai pu faire cette approximation. Mais je ne suis pas très fier de ce petit hack.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    SELECT
    	T1.*
    FROM 
    	Table_1 T1
    	INNER JOIN 
    		(SELECT
    			MAX(Id) as Id
    			, Utilisateur
    		FROM
    			Table_1
    		GROUP BY
    			Utilisateur) T2 ON T1.ID = T2.ID
    Ainsi, j'ai bien obtenu
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    - 9 : Jean   : 12 : 2019-05-07
    - 8 : Pierre : 15 : 2019-05-10
    - 7 : Céline : 0  : 2019-05-07
    Faire la somme de ces dernières estimations ne me pose plus de problèmes Mais aurai-je pu faire mieux ? Ou ai-je laissé fait une erreur quelque part ? Encore une fois, je n'ai pas réussi à récupérer la "dernière" estimation de chaque utilisateur. C'est seulement grâce à l'ID croissant que ça fonctionne...

    Je vais attendre un peu voir vos éventuelles réponses avant de marquer le sujet résolu.

  4. #4
    Expert éminent sénior
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 286
    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 286
    Points : 12 991
    Points
    12 991
    Par défaut
    Le problème est qu'un Id Auto ne garantit absolument pas un quelconque ordre dans les lignes. Il ne garantit que l'unicité (ce qui est déjà pas mal en soi).
    Si pour une raison ou une autre une ligne est insérée "à postériori", la requête ne fonctionne plus.
    Tu as une date pour chaque ligne, autant se baser dessus.

    Tatayo.

  5. #5
    Membre régulier
    Inscrit en
    Mai 2002
    Messages
    190
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 190
    Points : 83
    Points
    83
    Par défaut
    Ok,

    Alors voilà comment j'ai du adapter la requête :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    SELECT
    	T1.*
    FROM 
    	Table_1 T1
    	INNER JOIN 
    		(SELECT
    			MAX(Date) as Date
    			, Utilisateur
    		FROM
    			Table_1
    		GROUP BY
    			Utilisateur) T2 ON (T1.Date = T2.Date) AND (T1.Utilisateur = T2.Utilisateur)
    Et là, je retombe sur les même résultats attendus
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    - 8 : Pierre : 15 : 2019-05-10
    - 9 : Jean   : 12 : 2019-05-07
    - 7 : Céline : 0  : 2019-05-07
    Sans l'ajout du "AND (T1.Utilisateur = T2.Utilisateur)", je ressortais plus de lignes qu'attendues !

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

Discussions similaires

  1. [VxiR2] Faire une requete sur les résultats d'une première requete
    Par amy0o0 dans le forum Deski
    Réponses: 2
    Dernier message: 01/02/2011, 22h39
  2. [MySQL] Faire une Requete sur les enregistrements du jour même
    Par skins dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 16/04/2010, 11h36
  3. faire une croix sur les pics dans une figure
    Par jena dans le forum Signal
    Réponses: 5
    Dernier message: 28/11/2008, 19h04
  4. Réponses: 19
    Dernier message: 12/04/2007, 16h11
  5. Faire une sélection sur les cumuls : HAVING
    Par jpclabaux dans le forum Débuter
    Réponses: 3
    Dernier message: 20/10/2006, 16h44

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