Maison >base de données >tutoriel mysql >Comment trier les enregistrements de base de données par plusieurs valeurs dans une séquence spécifique ?

Comment trier les enregistrements de base de données par plusieurs valeurs dans une séquence spécifique ?

Barbara Streisand
Barbara Streisandoriginal
2025-01-08 18:12:41116parcourir

How to Order Database Records by Multiple Values in a Specific Sequence?

Tri multi-valeurs des enregistrements de la base de données dans un ordre spécifique

Supposons que vous ayez une table avec une clé indexée et un champ non indexé x_field. Vous devez rechercher tous les enregistrements avec une valeur spécifique et les renvoyer, puis trier les résultats en fonction de plusieurs valeurs dans un ordre spécifique.

Par exemple, si vous avez le tableau suivant :

id x_field
123 a
124 a
125 a
126 b
127 f
128 b
129 a
130 x
131 x
132 b
133 p
134 p
135 i

et vous souhaitez trier les résultats dans l'ordre suivant, où l'ordre est x_field = 'f', 'p', 'i', 'a' :

id x_field
127 f
133 p
134 p
135 i
123 a
124 a
125 a
129 a

Vous avez initialement essayé d'utiliser la requête suivante :

<code class="language-sql">SELECT *
FROM table
WHERE id NOT IN (126)
ORDER BY x_field 'f', 'p', 'i', 'a'</code>

Cependant, cette requête ne renvoie aucun résultat.

La façon de résoudre ce problème est d'utiliser l'instruction CASE pour attribuer une valeur numérique à chaque x_field valeur selon l'ordre souhaité :

<code class="language-sql">...
WHERE
   x_field IN ('f', 'p', 'i', 'a') ...
ORDER BY
   CASE x_field
      WHEN 'f' THEN 1
      WHEN 'p' THEN 2
      WHEN 'i' THEN 3
      WHEN 'a' THEN 4
      ELSE 5 -- 对不在 IN 子句中的值(例如:x_field = 'b')的回退值
   END, id</code>

Cette requête attribue la valeur 1 à la x_field valeur égale à 'f', la valeur 2 à la valeur égale à 'p', la valeur 3 à la valeur égale à 'i' et la valeur 4 à Égal à la valeur de « a ». Pour les valeurs ne figurant pas dans la clause IN (par exemple 'b'), une valeur de repli de 5 est attribuée. Les résultats sont ensuite triés par ordre croissant en fonction de cette valeur numérique et du champ id.

Cette approche garantit que les résultats sont triés dans l'ordre souhaité, même si x_field les valeurs ne sont pas par ordre décroissant/ascendant.

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn