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