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

DDD
發布: 2024-11-03 02:19:29
原創
969 人瀏覽過

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中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板