Home > Database > Mysql Tutorial > How Can I Prioritize Relevance in MySQL Fulltext Search for Different Fields?

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

Susan Sarandon
Release: 2024-11-04 01:44:30
Original
569 people have browsed it

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

Achieving Relevance Prioritization in MySQL Fulltext Search

When conducting fulltext searches across multiple fields, MySQL assigns equal relevance to matches found in each field. However, there may be scenarios where prioritizing certain fields is desirable, ensuring they contribute more significantly to the overall relevance score.

Solution: Create Weighted Indexes

To achieve this, create multiple fulltext indexes:

  • One on the field with higher priority (e.g., keywords)
  • One on the field with lower priority (e.g., content)
  • One on both fields combined (e.g., keywords, content)

Example Query with Weighted Relevance

Using the MATCH (keyword) AGAINST (...) and MATCH (content) AGAINST (...) functions, you can calculate separate relevance scores for each field. The CASE statement assigns binary values to indicate whether a specific field contains the search term:

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,
Copy after login

The above is the detailed content of How Can I Prioritize Relevance in MySQL Fulltext Search for Different Fields?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template