Requete SQL

Résolu/Fermé
Franck - 16 déc. 2011 à 13:16
 Franck - 16 déc. 2011 à 14:09
Bonjour,


Je voudrais faire la requete suivante :

Récupérer les identifiants de toutes les dernières commandes des clients.

SELECT MAX(DateCmd), IDClient
FROM Commande
GROUP BY IDClient;

Cette requete me renvoit bien les dernieres commandes, mais je voudrais les ID de ces requetes.

La requete suivante ;
SELECT MAX(DateCmd), IDCommande
FROM Commande
GROUP BY IDCommande;
me renvoie bien sur tous les enregistrements et pas seulement les dernieres commandes.


J'ai l'impression que c'est une requete toute simple, mais je n'y arrive pas...

Merci de votre aide.

6 réponses

Stringman621 Messages postés 1305 Date d'inscription mardi 13 décembre 2005 Statut Membre Dernière intervention 1 septembre 2012 337
16 déc. 2011 à 13:18
Bonjour,

Petite précision tu recherche, la dernière commande pour chaque client c'est bien ca ?
0
Oui c'est exactement ca. Il me faut surtout les ID ce des commandes.

Merci
0
Stringman621 Messages postés 1305 Date d'inscription mardi 13 décembre 2005 Statut Membre Dernière intervention 1 septembre 2012 337
16 déc. 2011 à 13:29
Je ne connais pas la structure de ta table COMMANDE mais je suppose qu'en clé étrangère tu doit avec l'id du client, donc la requête pourrait être :

SELECT MAX(DateCmd), IDCommande, IDClient
FROM Commande
GROUP BY IDClient;

Je ne suis pas sûr de la requête j'ai un doute sur le GROUP BY du fait que l'on utilisate la fonction MAX() il va peut être demandé IDCommande dans le GROUP BY mais essaie comme ça...
0
Stringman621 Messages postés 1305 Date d'inscription mardi 13 décembre 2005 Statut Membre Dernière intervention 1 septembre 2012 337
16 déc. 2011 à 13:32
Ou alors, en utilisant une sous-requête :

SELECT IDCommande
FROM Commande
WHERE DateCmd IN (
SELECT MAX(DateCmd)
FROM COMMANDE
GROUP BY IDClient);
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
Heremion Messages postés 539 Date d'inscription vendredi 20 mai 2011 Statut Membre Dernière intervention 1 juin 2022 102
16 déc. 2011 à 13:42
Bonjour Franck,

Ta requête est correcte et, en admettant que tes ID_COMMAND soient des auto_incrément, pourquoi ne pas lancer un
order by ID_COMMAND desc
?
0
La requete suivante ne fonctionne pas :
SELECT MAX(DateCmd), IDCommande, IDClient
FROM Commande
GROUP BY IDClient;

Il manque une rubrique dans le group by (IDCommande)
Mais si on l'ajoute, on a toutes les commandes

La requete suivante ne fonctionne pas non plus :
SELECT IDCommande
FROM Commande
WHERE DateCmd IN (
SELECT MAX(DateCmd)
FROM COMMANDE
GROUP BY IDClient);

Cette requete renvoie une ligne suplémentaire pour chaque commande avec la même date.

On m'a donné une solution qui marche tres bien :
SELECT tmp.IDClient, tmp.date_derniere_commande, c.IDCommande
FROM Commande c
INNER JOIN
(
SELECT IDClient, MAX(DateCmd) AS date_derniere_commande
FROM Commande
GROUP BY IDClient
) tmp
ON tmp.IDClient = c.IDClient
AND tmp.date_derniere_commande = c.DateCmd



Merci pour votre aide
0