Mongo高级查询语句-第二部分

next遍历游标

find()命令并不直接返回结果,而是返回一个结果集的迭代器,即游标。使用

象大多数数据库产品一样,MongoDB 也是用游标来循环处理每一条结果数据,具体语法如 下:

> for( var c = db.t3.find(); c.hasNext(); ) {
... printjson( c.next());
... }

输出结果如下:

{ "_id" : ObjectId("4fb8e4838b2cb86417c9423a"), "age" : 1 }
{ "_id" : ObjectId("4fb8e4878b2cb86417c9423b"), "age" : 2 }
{ "_id" : ObjectId("4fb8e4898b2cb86417c9423c"), "age" : 3 }
{ "_id" : ObjectId("4fb8e48c8b2cb86417c9423d"), "age" : 4 }
{ "_id" : ObjectId("4fb8e48e8b2cb86417c9423e"), "age" : 5 }

 

forEach遍历游标

MongoDB 还有另一种方式来处理游标,即forEach()方法:

> db.t3.find().forEach( function(u) { printjson(u); } );

结果如下:

{ "_id" : ObjectId("4fb8e4838b2cb86417c9423a"), "age" : 1 }
{ "_id" : ObjectId("4fb8e4878b2cb86417c9423b"), "age" : 2 }
{ "_id" : ObjectId("4fb8e4898b2cb86417c9423c"), "age" : 3 }
{ "_id" : ObjectId("4fb8e48c8b2cb86417c9423d"), "age" : 4 }

limit限制结果数量

要是限制返回的记录数量,可在find()后使用limit()函数。例如,只返回3个结果,可以这样:

> db.c.find().limit(3)

要是匹配的结果不到3个,则返回匹配数量的结果。limit()的参数指定的是 返回结果数量的上限,而非下限。

查询users文档中2个记录:

db.users.find().limit(2);

 

skip限制返回记录的起点

从第3 条记录开始,返回5 条记录(limit 3, 5)

db.users.find().skip(3).limit(5);

举例如下:

C1 表的数据如下:

> db.c1.find()
{ "_id" : ObjectId("4fb5faaf6d0f9d8ea3fc91a8"), "name" : "Tony", "age" : 20 }
{ "_id" : ObjectId("4fb5fab96d0f9d8ea3fc91a9"), "name" : "Joe", "age" : 10 }

查询users 表的第2 条数据

> db.users.find().skip(1).limit(1)

 

sort排序结果

以年龄升序(asc)排列:

db.users.find().sort({age: 1});

以年龄降序(desc)排列:

db.users.find().sort({age: -1});

C1 表的数据如下:

> db.c1.find()
{ "_id" : ObjectId("4fb5faaf6d0f9d8ea3fc91a8"), "name" : "Tony", "age" : 20 }
{ "_id" : ObjectId("4fb5fab96d0f9d8ea3fc91a9"), "name" : "Joe", "age" : 10 }

查询c1 表按age 升序排列

> db.c1.find().sort({age: 1});
{ "_id" : ObjectId("4fb5fab96d0f9d8ea3fc91a9"), "name" : "Joe", "age" : 10 }
{ "_id" : ObjectId("4fb5faaf6d0f9d8ea3fc91a8"), "name" : "Tony", "age" : 20 }

第1 条是age=10 的,而后升序排列结果集。

查询users表按age 降序排列:

> db.users.find().sort({age: -1});

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值