快速入门
安装
基本操作
数据模型
SQL引擎
系统架构
数据库管理
连接器
驱动
参考手册
故障排除
SAC
版本信息
query.sort( <sort> )
对结果集按指定字段排序。
参数名 | 参数类型 | 描述 | 是否必填 |
---|---|---|---|
sort | Json 对象 | 对结果集按指定字段排序。字段名的值为1或者-1,1代表升序;-1代表降序。 如果不设定 sort 则表示不对结果集做排序。 | 否 |
Note:
1. 当 find() 方法使用 sel 选项,若该选项没有包含 sort() 指定的排序字段,此时 sort() 方法设置的排序无意义,从而被自动忽略。
2. 如果不设定 sort 的内容,则对返回的结果集不排序。
格式:{ <字段名1>: <-1|1>, <字段名2>: <-1|1>, ... }
返回结果集的游标,类型为 object 。
> db.foo.bar.find( { age: { $gt: 20 } }, { age: "", name: "" } ).sort( { age: 1 } )
Note:
通过 find() 方法,我们能任意选择我们想要返回的字段名,在上例中我们选择了返回记录的 age 和 name 字段,此时用 sort() 方法时,只能对记录的 age 或 name 字段排序。而如果我们选择返回记录的所有字段,即不设置 find 方法的 sel 参数内容时,那么 sort() 能对任意字段排序。
> db.foo.bar.find( { age: { $gt: 20 } }, { age: "", name: "" } ).sort( { "sex": 1 } )
Note:
因为“sex”字段并不存在 find() 方法的 sel 选项 {age:"",name:""} 中,所以 sort() 指定的排序字段 {"sex":1} 将被忽略。