Maison >base de données >tutoriel mysql >Comment puis-je classer les résultats de recherche MySQL par « meilleure correspondance » en fonction de la position du terme de recherche ?
Ordre des résultats MySQL en fonction de la « meilleure correspondance »
Dans ce scénario, l'objectif est d'améliorer une requête de recherche en direct MySQL pour hiérarchiser les résultats où le terme de recherche apparaît plus tôt dans le mot.
Actuellement, la requête trie les résultats par ordre alphabétique :
SELECT word FROM words WHERE word LIKE '%searchstring%' ORDER BY word ASC
Pour obtenir le tri souhaité, nous pouvons introduire une logique conditionnelle pour différencier les positions du terme de recherche dans les résultats.
Tri par Début, Milieu, Fin du mot
Pour organiser les résultats où les correspondances au début du mot sont priorisées, nous pouvons utiliser ce qui suit requête :
SELECT word FROM words WHERE word LIKE '%searchstring%' ORDER BY CASE WHEN word LIKE 'searchstring%' THEN 1 WHEN word LIKE '%searchstring' THEN 3 ELSE 2 END
Cette requête attribue des pondérations à chaque résultat : 1 pour les correspondances parfaites commençant par le terme de recherche, 3 pour les correspondances n'importe où dans le mot et 2 dans le cas contraire. Ces poids déterminent l'ordre de tri.
Tri par position de la chaîne correspondante
Si nous voulons trier les résultats en fonction de la position exacte de la correspondance, nous pouvons exploiter le Fonction LOCATE :
SELECT word FROM words WHERE word LIKE '%searchstring%' ORDER BY LOCATE('searchstring', word)
Cette requête calcule la position du terme de recherche dans chaque résultat et trie en conséquence.
Gestion des égalités
Dans les cas où plusieurs résultats ont le même score ou la même position, nous pouvons introduire un critère de tri secondaire :
SELECT word FROM words WHERE word LIKE '%searchstring%' ORDER BY <whatever>, word
En remplaçant
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!