Précédent   Forum des professionnels en informatique > Bases de données > MySQL > Débuter
Débuter Forum d'entraide pour débuter avec MySQL
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 02/12/2007, 21h10   #1
Invité de passage
 
Inscription : novembre 2007
Messages : 6
Détails du profil
Informations forums :
Inscription : novembre 2007
Messages : 6
Points : 2
Points : 2
Par défaut Retrouver les X précédents

Encore un problème de débutant...

Soit une table avec ID pour seul champ:

ID
9
8
7
6
5
4
3
2
1

A partir de n'importe quel ID, comment obtenir les 3 précédents, dans l'ordre décroissant?

J'essaie ça:
Code :
SELECT id FROM TABLE WHERE id>$id ORDER BY id DESC LIMIT $id,3
Qui me renvoie un petit peu n'importe quoi:

En choisissant 5, je voudrais obtenir le 8 (j'obtiens un résultat nul)
En choisissant 2, je voudrais obtenir le 5 (j'obtiens 7)
En choisissant 7, je voudrais obtenir le 9 (j'obtiens un résultat nul)

Quelqu'un pour m'aider s'il vous plait?
Uzco2000 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 02/12/2007, 21h51   #2
Rédacteur/Modérateur

 
Avatar de Antoun
 
Homme Antoine Dinimant
Consultant en Business Intelligence
Inscription : octobre 2006
Messages : 5 854
Détails du profil
Informations personnelles :
Nom : Homme Antoine Dinimant
Âge : 42
Localisation : France, Paris (Île de France)

Informations professionnelles :
Activité : Consultant en Business Intelligence
Secteur : Conseil

Informations forums :
Inscription : octobre 2006
Messages : 5 854
Points : 9 540
Points : 9 540
Code :
1
2
3
4
5
SELECT id 
FROM TABLE 
WHERE id>$id 
ORDER BY id DESC 
LIMIT 3
__________________
Antoun
Expert SQL, BO, Essbase

La bible d'Essbase est parue !
Antoun est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 03/12/2007, 04h24   #3
Invité de passage
 
Inscription : novembre 2007
Messages : 6
Détails du profil
Informations forums :
Inscription : novembre 2007
Messages : 6
Points : 2
Points : 2
Par défaut Merci, mais...

Merci pour cette proposition, mais ça ne convient pas. Cette requête va me donner les 3 premiers résultats correspondant au WHERE, mais pas ceux les plus proches de $ID.

ID
9
8
7
6
5
4
3
2
1

Pour un ID à 4, ta requête me donne le résultat 9, 8, 7, alors que j'aimerais obtenir 7, 6, 5. Il me faut les trois premiers directement voisins de mon $ID.

J'ai cru comprendre que le LIMIT se faisait a posteriori, un peu comme un filtre sur le résultat de la requête.

Je suis drôlement embêté, en tout cas.

Merci pour votre aide.
Uzco2000 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 03/12/2007, 07h24   #4
Rédacteur/Modérateur

 
Avatar de Antoun
 
Homme Antoine Dinimant
Consultant en Business Intelligence
Inscription : octobre 2006
Messages : 5 854
Détails du profil
Informations personnelles :
Nom : Homme Antoine Dinimant
Âge : 42
Localisation : France, Paris (Île de France)

Informations professionnelles :
Activité : Consultant en Business Intelligence
Secteur : Conseil

Informations forums :
Inscription : octobre 2006
Messages : 5 854
Points : 9 540
Points : 9 540
Code :
1
2
3
4
5
SELECT id 
FROM TABLE 
WHERE id>$id 
ORDER BY id ASC 
LIMIT 3
__________________
Antoun
Expert SQL, BO, Essbase

La bible d'Essbase est parue !
Antoun est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 03/12/2007, 12h58   #5
Invité de passage
 
Inscription : novembre 2007
Messages : 6
Détails du profil
Informations forums :
Inscription : novembre 2007
Messages : 6
Points : 2
Points : 2
Par défaut Dans le mille

Merci Antoun, ça marche !

J'évite le smiley qui lève et agite les bras, mais le coeur y est.
Uzco2000 est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 07h45.


 
 
 
 
Partenaires

Hébergement Web