Requete SQL
Résolu
Franck
-
Franck -
Franck -
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.
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.
A voir également:
- Requete SQL
- Logiciel sql - Télécharger - Bases de données
- Sql lister les tables ✓ - Forum Programmation
- Sql (+) - Forum Programmation
- Jointure sql ✓ - Forum MySQL
- Erreur lors de l'envoi de la requête facebook - Forum Facebook
6 réponses
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...
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...
Ou alors, en utilisant une sous-requête :
SELECT IDCommande
FROM Commande
WHERE DateCmd IN (
SELECT MAX(DateCmd)
FROM COMMANDE
GROUP BY IDClient);
SELECT IDCommande
FROM Commande
WHERE DateCmd IN (
SELECT MAX(DateCmd)
FROM COMMANDE
GROUP BY IDClient);
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Bonjour Franck,
Ta requête est correcte et, en admettant que tes ID_COMMAND soient des auto_incrément, pourquoi ne pas lancer un
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?
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
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