首頁  >  文章  >  資料庫  >  如何以相關性對 MySQL 全文搜尋結果進行排序?

如何以相關性對 MySQL 全文搜尋結果進行排序?

DDD
DDD原創
2024-11-03 02:19:29932瀏覽

How can I sort MySQL fulltext search results by relevancy?

按相關性對 MySQL 全文搜尋結果進行排序

使用 MySQL 時,了解 LIKE 和全文搜尋之間的區別對於準確的結果排序至關重要。

在提供的查詢中:

$query="SELECT * from `vocabulary` WHERE translation = 'word' OR translation LIKE '%word%'";

LIKE 運算子用於部分匹配,而不是全文搜尋。若要執行全文搜索,請使用 MATCH(...) AGAINST(...) 語法。

例如:

$query="SELECT * from `vocabulary` WHERE MATCH(translation) AGAINST('+word')";

MATCH 函數傳回一個符合分數,可以是用來作為相關性的近似值。此分數可用於對結果進行排序。例如:

$query="SELECT *, MATCH(translation) AGAINST('+word') AS score FROM `vocabulary` ORDER BY score DESC";

此查詢會依相關性對結果排序,得分最高的符合項首先出現。

以上是如何以相關性對 MySQL 全文搜尋結果進行排序?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn