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); }