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 ?

Comment puis-je classer les résultats de recherche MySQL par « meilleure correspondance » en fonction de la position du terme de recherche ?

DDD
DDDoriginal
2024-12-30 00:37:20961parcourir

How Can I Order MySQL Search Results by

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 avec un champ pertinent (par exemple, la fréquence des mots), nous pouvons briser les égalités et trier davantage les résultats.

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