2

我有一个搜索查询,它根据文章中使用该术语的次数对结果进行排序。例如标题中有 1 次,内容中有 1 次。与仅在其内容区域中具有 te 术语的文章相比,这篇文章最终在列表中的排名更高。但我想要一点额外的东西,是否可以添加乘数,例如当标题中使用该术语时,它计为 2 而不是 1。看下面的代码:

<?PHP

//SET THE SEARCH TERM
$term = "Search Term";

$sql = "SELECT *, MATCH(subject, message,reference,textbody) AGAINST('". $term ."') as score FROM pages WHERE MATCH (subject, message,reference,textbody) AGAINST('". $term ."') ORDER BY score DESC";
$query = mysql_query($sql);

//BUILD A LIST OF THE RESULTS
while($result = mysql_fetch_assoc($query)) {
   // your stuff for showing result
}
?>

你能帮帮我吗?

4

2 回答 2

1

MySQL 的 MATCH 函数没有加权字段的功能。您必须在要具有更高权重的字段上创建单独的全文索引,然后使用单独的 MATCH() 表达式计算与两个全文索引的相关性。

SELECT *, 
  MATCH(subject) AGAINST('". $term ."') * 2 AS score_s /* 2x weight */
  MATCH(subject, message, reference, textbody) AGAINST('". $term ."') AS score
FROM pages 
WHERE 
  MATCH(subject, message, reference, textbody) AGAINST('". $term ."') 
ORDER BY score_s + score DESC

MySQL 内置的全文搜索确实不是很灵活。当您有特定的功能要求时,其他专用工具通常是更好的选择:

这些其他工具在搜索大型数据集时通常也快得多。请参阅我的演示文稿Fulltext Search Throwdown进行比较。

于 2013-09-29T19:00:33.260 回答
1

像这样添加+1

$sql = "SELECT *, MATCH(subject, message,reference,textbody) AGAINST('". $term ."')+1 as score 
             FROM pages  ORDER BY score DESC";
于 2013-09-29T18:53:48.663 回答