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!