(没有可用的版本信息,可能仅在 Git 中)
CollectionFind::sort — 设置排序条件
根据 sort_expr 参数中选择的字段对结果集进行排序。允许的顺序为 ASC(升序)或 DESC(降序)。此操作等效于“ORDER BY”SQL 操作,并遵循相同的规则集。
sort_expr可以提供一个或多个排序表达式。评估顺序从左到右,每个表达式用逗号分隔。
一个 CollectionFind 对象,可用于执行命令或添加其他操作。
示例 #1 mysql_xdevapi\CollectionFind::sort() 示例
<?php
$session = mysql_xdevapi\getSession("mysqlx://user:password@localhost");
$session->sql("DROP DATABASE IF EXISTS addressbook")->execute();
$session->sql("CREATE DATABASE addressbook")->execute();
$schema = $session->getSchema("addressbook");
$create = $schema->createCollection("people");
$create
->add('{"name": "Alfred", "age": 18, "job": "Butler"}')
->execute();
$create
->add('{"name": "Reginald", "age": 42, "job": "Butler"}')
->execute();
// ...
$collection = $schema->getCollection("people");
$result = $collection
->find()
->sort('job desc', 'age asc')
->execute();
var_dump($result->fetchAll());
?>以上示例将输出类似以下内容
array(2) {
[0]=>
array(4) {
["_id"]=>
string(28) "00005b6b53610000000000000106"
["age"]=>
int(18)
["job"]=>
string(6) "Butler"
["name"]=>
string(6) "Alfred"
}
[1]=>
array(4) {
["_id"]=>
string(28) "00005b6b53610000000000000107"
["age"]=>
int(42)
["job"]=>
string(6) "Butler"
["name"]=>
string(8) "Reginald"
}
}