(No version information available, might only be in Git)
CollectionFind::sort â DĂ©finit les critĂšres de tri
Trie le jeu de rĂ©sultats par le champ sĂ©lectionnĂ© dans l'argument sort_expr. Les ordres autorisĂ©s sont ASC (Ascendant) ou DESC (Descendant). Cette opĂ©ration est Ă©quivalente Ă l'opĂ©ration 'ORDER BY' SQL et suit le mĂȘme ensemble de rĂšgles.
sort_exprUne ou plusieurs expressions de tri peuvent ĂȘtre fournies. L'Ă©valuation se fait de gauche Ă droite, et chaque expression est sĂ©parĂ©e par une virgule.
Un objet CollectionFind qui peut ĂȘtre utilisĂ© pour exĂ©cuter la commande, ou pour ajouter des opĂ©rations supplĂ©mentaires.
Exemple #1 Exemple de 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());
?>Résultat de l'exemple ci-dessus est similaire à :
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"
}
}