Maison > Article > base de données > Comment trier les résultats MySQL selon l'ordre spécifié dans la clause IN() ?
MySQL : Trier les résultats par ordre de spécification IN()
Lors de la récupération de données avec une clause IN(), maintenir l'ordre dans lequel les valeurs ont été spécifiées peuvent améliorer la lisibilité et la convivialité de la sortie. Cet article explore une solution pour trier les résultats en fonction de la séquence de valeurs dans la fonction IN().
Considérez la requête suivante :
SELECT id, name FROM mytable WHERE name IN ('B', 'A', 'D', 'E', 'C');
Cette requête renvoie le résultat suivant, où l'ordre des lignes n'est pas cohérent avec l'ordre dans la clause IN() :
| identifiant | nom |
^--------^---------^
| 5 | B |
| 6 | B |
| 1 | D |
| 15 | E |
| 17 | E |
| 9 | C |
| 18 | C |
Pour trier les résultats dans l'ordre spécifié dans la clause IN(), nous pouvons utiliser la fonction FIELD. La fonction FIELD prend une valeur comme premier argument et renvoie la position de cette valeur dans la liste d'arguments restante.
La requête suivante utilise la fonction FIELD pour trier les résultats en fonction de la position du « nom » valeurs de colonne dans la liste ("B", "A", "D", "E", "C") :
SELECT id, name FROM mytable WHERE name IN ('B', 'A', 'D', 'E', 'C') ORDER BY FIELD(name, 'B', 'A', 'D', 'E', 'C')
Cette requête renvoie le résultat suivant :
| identifiant | nom |
^--------^---------^
| 5 | B |
| 6 | B |
| 1 | D |
| 15 | E |
| 17 | E |
| 9 | C |
| 18 | C |
Comme vous pouvez le voir, les lignes sont désormais classées dans l'ordre initialement spécifié dans la clause IN().
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!