CollectionFind::sort

(No version information available, might only be in Git)

CollectionFind::sortソート条件を設定する

説明

publicmysql_xdevapi\CollectionFind::sort(string$sort_expr): mysql_xdevapi\CollectionFind

sort_expr 引数で、選択されるフィールドによって結果をソートします。 可能なソート順は ASC(昇順) または DESC (降順) です。 この操作は SQL の 'ORDER BY' と同等で、同じルールに従います。

パラメータ

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" } }
To Top