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 중국어 웹사이트의 기타 관련 기사를 참조하세요!