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
Libérer: 2025-01-08 18:12:41
original
150 Les gens l'ont consulté

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>
Copier après la connexion

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>
Copier après la connexion

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!

source:php.cn
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal