Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1558356
  • 博文数量: 1481
  • 博客积分: 26784
  • 博客等级: 上将
  • 技术积分: 17045
  • 用 户 组: 普通用户
  • 注册时间: 2011-07-12 09:22
文章分类

全部博文(1481)

文章存档

2014年(10)

2013年(353)

2012年(700)

2011年(418)

分类: 系统运维

2012-08-08 09:25:18

一:Sphinx(coreseek)的查询默认最大记录数是:1000,而我们想更改这个数值。就需要更改二个地方。

1是更改csft.conf(如果是sphinx就是sphinx.conf)配置文件的:max_matches = 10000 #后面数字就是你想查询的最大记录数。建议在1000~10000之内。
2是在api调用时,$cl->SetLimits($pageStart, $pageSize, $max_limits);用SetLimits的第三个参数更改为你想要的显示最大记录数。
经过这二个配置和程序更改,你再查询看看呢!(注意你搜索要有这么多记录哦。呵)


二:sphinx的高亮。

开始按程序来设置高亮,都是没问题的。因为都是英文嘛。问题点主要是出现在中文的高亮上面。我的页面和数据库都是gbk编码。
所以做了如下配置和程序更改。

$opts = array(
"before_match" => "",
"after_match" => "
",
"chunk_separator" => "..",
"limit" => 10,
"around" => 3
);

//$docs必须是数组传进来哦

function search_highlight($docs) {
$this->s_keywords = iconv('gbk', 'utf-8', $this->s_keywords);
$docs[0] = iconv('gbk', 'utf-8', $docs[0]);
$arr_words = $this->h_cl->BuildExcerpts ( $docs, $this->s_index, $this->s_keywords, $this->h_opts);
$arr_words[0] = iconv('utf-8', 'gbk', $arr_words[0]);
$this->s_keywords = iconv('utf-8', 'gbk', $this->s_keywords);
return $arr_words;
}
至此,中文高亮就显示正常了


三:搜索排序

默认我用了:$cl->SetMatchMode(SPH_SORT_RELEVANCE);,
而我如果想把最新的结果显示在前面,必须要用SPH_SORT_TIME_SEGMENTS模式。
所以我在配置文件里加上了:sql_attr_timestamp = add_time
在程序中就加上了:$cl->SetSortMode(SEGMENTS, 'add_time');
这样就正常了!

原文地址:

阅读(332) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~