所谓的游标就是指的数据可以一行一行的进行操作,非常类似与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的游标操作最简单的,最直观的。
● 判断是否有下一行数据: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/