MongoDB之游标

所谓的游标就是指的数据可以一行一行的进行操作,非常类似与ResultSet数据处理,在MongoDB数据库里面,对于游标的控制非常简单,只需要使用find()函数就可以返回游标了。对于返回的游标,如果要想进行操作,可以使用两个函数:
  ● 判断是否有下一行数据:lastNext();
  ● 取出当前数据:next()。

> var cursor=db.emp.find();
> cursor.hasNext();
true
> cursor.next();
{
        "_id" : ObjectId("599294320184ff511bf02b97"),
        "name" : "赵一",
        "sex" : "男",
        "age" : 30,
        "sal" : 1000,
        "loc" : "北京"
}

以上是游标的操作形式,但是实际上不可能这么去用,因为必须利用循环才能够输出内容。

范例:编写具体的操作代码
> var cursor=db.emp.find();
> while (cursor.hasNext()){
... var doc=cursor.next();
... print(doc.name);
... }
赵一
钱二
孙三
李四
周五
吴六
郑七
王八
刘A
刘B
刘C
刘D
刘E
林A
林B
林C
林D

> var cursor=db.emp.find();
> while (cursor.hasNext()){ var doc=cursor.next(); print(doc); }
[object BSON]
[object BSON]
[object BSON]
[object BSON]
[object BSON]
[object BSON]
[object BSON]
[object BSON]
[object BSON]
[object BSON]
[object BSON]
[object BSON]
[object BSON]
[object BSON]
[object BSON]
[object BSON]
[object BSON]
[object BSON]

相当于每一个数据都单独拿出来逐行的控制。当游标数据取出来之后,实际上每行数据返回的都是一个Object型的内容,那么如果需要将数据按照JSON的形式出现,则可以使用printjson()函数完成。

> var cursor=db.emp.find();
> while (cursor.hasNext()){ var doc=cursor.next(); printjson(doc); }
{
        "_id" : ObjectId("599294320184ff511bf02b97"),
        "name" : "赵一",
        "sex" : "男",
        "age" : 30,
        "sal" : 1000,
        "loc" : "北京"
}

在所有的已知数据库,只有MongoDB的游标操作最简单的,最直观的。


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

转载于:http://blog.itpub.net/28536251/viewspace-2144100/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值