Pouvez-vous trier par une instruction conditionnelle ?
En SQL, la clause ORDER BY vous permet de spécifier l'ordre dans lequel vos résultats seront être restitué. Cependant, que se passe-t-il si vous souhaitez trier dynamiquement vos résultats en fonction d'une condition spécifique ?
Problème :
Un utilisateur souhaite trier les données différemment en fonction de la valeur dans un colonne intitulée « Type ». Si le type est « Membre », ils souhaitent trier par nom de famille, et s'il s'agit de « Groupe », ils souhaitent trier par nom de groupe, tous deux par ordre croissant.
Approche initiale :
L'utilisateur a tenté d'utiliser une instruction if dans ORDER BY clause :
ORDER BY ((LNAME if TYPE = 'Member') OR (GROUPNAME if TYPE = 'Group')) ASC
Solution :
Bien que le concept soit correct, SQL ne prend pas en charge les instructions if dans la clause ORDER BY. Au lieu de cela, vous pouvez utiliser soit la fonction IF, soit l'instruction CASE.
Utilisation de la fonction IF :
ORDER BY IF(TYPE='Member', LNAME, GROUPNAME) ASC
Cette approche utilise la fonction IF pour évaluer la condition et renvoyez le champ de tri approprié.
Utilisation du CASE Déclaration :
ORDER BY CASE `type` WHEN 'Member' THEN LNAME WHEN 'Group' THEN GROUPNAME ELSE 1 END ASC
L'instruction CASE fournit un moyen plus complet de gérer plusieurs conditions et de renvoyer différents champs de tri en fonction de chaque condition.
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!