MongoDB操作之遍历集和条件查询操作

连接MongoDB:

C:\Users\duansf>mongo
MongoDB shell version: 2.6.6
connecting to: test
> use test
switched to db test
> show tables
articles
books
system.indexes
test
things
users
 遍历集例子:
方法1:
> var cursor = db.things.find();
> while (cursor.hasNext()) { print(tojson(cursor.next())); }
{ "_id" : ObjectId("5652d71a1524dc14663060e8"), "x" : 4, "j" : 2 }
{ "_id" : ObjectId("5652d71a1524dc14663060e9"), "x" : 4, "j" : 3 }
{ "_id" : ObjectId("5652d71a1524dc14663060ea"), "x" : 4, "j" : 4 }
{ "_id" : ObjectId("5652d71a1524dc14663060eb"), "x" : 4, "j" : 5 }
{ "_id" : ObjectId("5652d71a1524dc14663060ec"), "x" : 4, "j" : 6 }
{ "_id" : ObjectId("5652d71a1524dc14663060ed"), "x" : 4, "j" : 7 }
{ "_id" : ObjectId("5652d71a1524dc14663060ee"), "x" : 4, "j" : 8 }
{ "_id" : ObjectId("5652d71a1524dc14663060ef"), "x" : 4, "j" : 9 }
>
方法2:
> db.things.find().forEach( function(x){print(tojson(x));});
{ "_id" : ObjectId("5652d71a1524dc14663060e8"), "x" : 4, "j" : 2 }
{ "_id" : ObjectId("5652d71a1524dc14663060e9"), "x" : 4, "j" : 3 }
{ "_id" : ObjectId("5652d71a1524dc14663060ea"), "x" : 4, "j" : 4 }
{ "_id" : ObjectId("5652d71a1524dc14663060eb"), "x" : 4, "j" : 5 }
{ "_id" : ObjectId("5652d71a1524dc14663060ec"), "x" : 4, "j" : 6 }
{ "_id" : ObjectId("5652d71a1524dc14663060ed"), "x" : 4, "j" : 7 }
{ "_id" : ObjectId("5652d71a1524dc14663060ee"), "x" : 4, "j" : 8 }
{ "_id" : ObjectId("5652d71a1524dc14663060ef"), "x" : 4, "j" : 9 }
>
获取结果集:
> var cursor = db.things.find();
> print (tojson(cursor[4]));
{ "_id" : ObjectId("5652d71a1524dc14663060ec"), "x" : 4, "j" : 6 }
> var arr = db.things.find().toArray();
> arr[5];
{ "_id" : ObjectId("5652d71a1524dc14663060ed"), "x" : 4, "j" : 7 }
>

条件查询:
> db.books.find({name:"18book"}).forEach(function(x) { print(tojson(x));})
{
        "_id" : ObjectId("5650645db9bb2b1fd5ba07b5"),
        "number" : 18,
        "name" : "18book"
}
{
        "_id" : ObjectId("5652d7411524dc1466306102"),
        "number" : 18,
        "name" : "18book"
}
>

等价于:

SQL:SELECT * FROM books WHERE name="18book";

> db.things.find({x:4}, {j:true}).forEach(function(x) { print(tojson(x));});
{ "_id" : ObjectId("5652d71a1524dc14663060e8"), "j" : 2 }
{ "_id" : ObjectId("5652d71a1524dc14663060e9"), "j" : 3 }
{ "_id" : ObjectId("5652d71a1524dc14663060ea"), "j" : 4 }
{ "_id" : ObjectId("5652d71a1524dc14663060eb"), "j" : 5 }
{ "_id" : ObjectId("5652d71a1524dc14663060ec"), "j" : 6 }
{ "_id" : ObjectId("5652d71a1524dc14663060ed"), "j" : 7 }
{ "_id" : ObjectId("5652d71a1524dc14663060ee"), "j" : 8 }
{ "_id" : ObjectId("5652d71a1524dc14663060ef"), "j" : 9 }
>

等价于:

SQL:SELECT j FROM things WHERE x=4

findOne用法:
> var mongo = db.books.findOne({name:"18book"});
>
>
> print(tojson(mongo));
{
        "_id" : ObjectId("5650645db9bb2b1fd5ba07b5"),
        "number" : 18,
        "name" : "18book"
}


limit用法:
> db.things.find().limit(3);
{ "_id" : ObjectId("5652d71a1524dc14663060e8"), "x" : 4, "j" : 2 }
{ "_id" : ObjectId("5652d71a1524dc14663060e9"), "x" : 4, "j" : 3 }
{ "_id" : ObjectId("5652d71a1524dc14663060ea"), "x" : 4, "j" : 4 }
>
等价于:
SQL:SELECT j from things WHERE rownum< 4;



来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/15498/viewspace-1982493/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/15498/viewspace-1982493/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值