我有一个搜索查询,根据文章中使用的术语次数对结果进行排序。例如,标题中有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
}
?>
你能帮帮我吗?
答案 0 :(得分:1)
只需添加+1
就可以了
$sql = "SELECT *, MATCH(subject, message,reference,textbody) AGAINST('". $term ."')+1 as score
FROM pages ORDER BY score DESC";
答案 1 :(得分: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的内置全文搜索真的不是很灵活。当您有特定的功能要求时,其他专业工具通常是更好的选择:
狮身人面像搜索支持相关性排名,使用扩展匹配模式时的默认排名是按字频,这似乎是您所要求的。
http://sphinxsearch.com/blog/2010/08/17/how-sphinx-relevance-ranking-works/
Apache Solr 支持“提升”与给定字段匹配的字词的权重。 http://wiki.apache.org/solr/SolrRelevancyFAQ#How_can_I_make_.22superman.22_in_the_title_field_score_higher_than_in_the_subject_field
这些其他工具通常也可以更快地搜索大型数据集。请参阅我的演示文稿Fulltext Search Throwdown进行比较。