>데이터 베이스 >MySQL 튜토리얼 >관련성에 따라 MySQL 검색 결과를 정렬하는 방법: 일치 항목을 먼저 시작합니까?

관련성에 따라 MySQL 검색 결과를 정렬하는 방법: 일치 항목을 먼저 시작합니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-30 08:10:10385검색

How to Order MySQL Search Results by Relevance: Beginning Matches First?

관련성에 따른 MySQL 결과 정렬: 가장 일치하는 항목 우선

MySQL 데이터베이스에서 실시간 검색 기능에는 관련성을 기준으로 결과를 정렬하는 경우가 많습니다. 기본적으로 결과는 알파벳순으로 정렬되지만 검색 문자열이 단어의 시작 부분과 일치하는 결과의 우선순위를 지정하려면 어떻게 해야 합니까?

이를 달성하려면 CASE 문과 패턴 일치를 활용하여 사용자 정의를 생성할 수 있습니다. order:

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

이 쿼리는 검색 문자열이 단어 시작 부분에 나타나는 결과에 1의 우선순위를 할당하고, 단어 내에서 문자열이 일치하는 결과에 3을 할당합니다. 2를 나머지 일치 항목에 적용합니다.

또는 일치하는 문자열의 위치를 ​​기준으로 정렬하려면 LOCATE 함수를 사용할 수 있습니다.

SELECT word
FROM words
WHERE word LIKE '%searchstring%'
ORDER BY LOCATE('searchstring', word)

이 쿼리는 문자열의 위치를 ​​기준으로 결과를 정렬합니다. 단어 내 검색 문자열, 단어 앞부분에서 찾은 일치 항목에 우선순위를 부여합니다.

마지막으로 여러 단어가 검색어와 일치하는 동점의 경우 문자열에 대해 보조 정렬 규칙을 추가하여 각 우선순위 그룹 내의 결과를 알파벳순으로 정렬할 수 있습니다.

SELECT word
FROM words
WHERE word LIKE '%searchstring%'
ORDER BY <whatever>, word

검색 문자열 위치에 따라 사용자 정의 순서를 수행함으로써 검색 결과의 관련성을 높이고 검색 결과의 효율성을 향상할 수 있습니다. 사용자 경험.

위 내용은 관련성에 따라 MySQL 검색 결과를 정렬하는 방법: 일치 항목을 먼저 시작합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.