>  기사  >  데이터 베이스  >  다양한 필드에 대한 MySQL 전체 텍스트 검색에서 관련성의 우선순위를 어떻게 정할 수 있습니까?

다양한 필드에 대한 MySQL 전체 텍스트 검색에서 관련성의 우선순위를 어떻게 정할 수 있습니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-04 01:44:30491검색

How Can I Prioritize Relevance in MySQL Fulltext Search for Different Fields?

MySQL 전체 텍스트 검색에서 관련성 우선순위 달성

여러 필드에 걸쳐 전체 텍스트 검색을 수행할 때 MySQL은 각 필드에서 찾은 일치 항목에 동일한 관련성을 할당합니다. 그러나 특정 필드의 우선 순위를 지정하여 해당 필드가 전체 관련성 점수에 더 크게 기여하도록 하는 것이 바람직한 시나리오가 있을 수 있습니다.

해결책: 가중치 인덱스 생성

이를 달성하려면 , 여러 개의 전체 텍스트 인덱스 생성:

  • 우선 순위가 높은 필드에 하나(예: 키워드)
  • 우선 순위가 낮은 필드에 하나(예: 콘텐츠)
  • 두 필드 중 하나 결합(예: 키워드, 콘텐츠)

가중치 관련성이 있는 쿼리 예시

MATCH(키워드) AGAINST(... ) 및 MATCH(content) AGAINST(...) 함수를 사용하면 각 필드에 대해 별도의 관련성 점수를 계산할 수 있습니다. CASE 문은 특정 필드에 검색어가 포함되어 있는지 여부를 나타내는 이진 값을 할당합니다.

SELECT *, 
CASE WHEN Keywords LIKE '%watermelon%' THEN 1 ELSE 0 END AS keywordmatch, 
CASE WHEN Content LIKE '%watermelon%' THEN 1 ELSE 0 END AS contentmatch,

위 내용은 다양한 필드에 대한 MySQL 전체 텍스트 검색에서 관련성의 우선순위를 어떻게 정할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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