可使用如下模式对搜索结果排序:
- SPH_SORT_RELEVANCE 模式, 按相关度降序排列(最好的匹配排在最前面)
- SPH_SORT_ATTR_DESC 模式, 按属性降序排列 (属性值越大的越是排在前面)
- SPH_SORT_ATTR_ASC 模式, 按属性升序排列(属性值越小的越是排在前面)
- SPH_SORT_TIME_SEGMENTS 模式, 先按时间段(最近一小时/天/周/月)降序,再按相关度降序
- SPH_SORT_EXTENDED 模式, 按一种类似SQL的方式将列组合起来,升序或降序排列。
- SPH_SORT_EXPR 模式,按某个算术表达式排序。
SPH_SORT_EXTENDED 模式
在 SPH_SORT_EXTENDED 模式中,您可以指定一个类似SQL的排序表达式,但涉及的属性(包括内部属性)不能超过5个,例如:
@relevance DESC, price ASC, @id DESC
只要做了相关设置,不管是内部属性(引擎动态计算出来的那些属性)还是用户定义的属性就都可以使用。内部属性的名字必须用特殊符号@开头,用户属性按原样使用就行了。在上面的例子里,@relevance
和@id
是内部属性,而price
是用户定义属性。
已知的内置属性:
- @id (匹配文档的 ID)
- @weight (匹配权值)
- @rank (等同 weight)
- @relevance (等同 weight)
- @random (随机顺序返回结果)
@rank
和 @relevance
只是 @weight
的别名.
PHP 的 API 中只有 SetSortMode($mode, $sortBy) 方法.从上面的文档说明中可知,如果需要设置多个字段依次排序。需要使用下列代码:
$SphinxClient->SetSortMode(SPH_SORT_EXTENDED, "columnA ASC, columnB DESC, columnC ASC");
无法方便的同时设置多个排序。通过继承 SphinxClient 类添加了一个新方法,实现了通过数组设置多个排序。
/**
* 设定多重排序条件
* @param Array $orders 排序条件数组
* @example $order = array (
* '0' => array ('attribute' => 'columnname', 'order' => RentSearch::DESC),
* '1' => array (//...),
* );
*/
public function multiOrder($orders) {
$orderType = SPH_SORT_EXTENDED;
$orderString = "";
foreach ($orders as $order) {
switch ($order['order']) {
case self::ASC :
$orderString += $order['attribute'] . ' ASC, ';
break;
case self::DESC :
$orderString += $order['attribute'] . ' DESC, ';
break;
default :
$orderString += $order['attribute'] . ' DESC, ';
break;
}
}
$orderString = substr($orderString, 0, strlen($orderString)-2);
$this->SetSortModel($orderType, $orderString);
}