遊標

遊標操作 cursor

遊標是什麼\?
通俗的說,遊標不是查詢結果,而是查詢的返回資源,或者接口.
通過這個接口,你可以逐條讀取.
就像php中的fopen打開文件,得到一個資源一樣, 通過資源,可以一行一行的讀文件.

聲明遊標:
var cursor = db.collectioName.find(query,projection);
Cursor.hasNext() ,判斷遊標是否已經取到盡頭
Cursor. Next() , 取出遊標的下1個單元

用while來循環遊標

var mycursor = db.bar.find({_id:{$lte:5}})
while(mycursor.hasNext()) {
... printjson(mycursor.next());
... }
遊標

(注意:調用next()則遊標已經到了第二個,所以_id爲1的不會輸出。沒有下一個了則會報錯)

遊標

例:
// 聲明遊標
var cursor = db.goods.find();
// 循環遊標
for(var doc=true;cursor.hasNext();) { printjson(cursor.next());}

也可以簡寫:
for(var cursor=db.goods.find(), doc=true;cursor.hasNext();) { printjson(cursor.next());}

遊標還有一個迭代函數,允許我們自定義回調函數來逐個處理每個單元.
cursor.forEach(回調函數);
例:
var gettitle = function(obj) {print(obj.goods_name)}
var cursor = db.goods.find();
cursor.forEach(gettitle);

遊標

遊標在分頁中的應用
比如查到10000行,跳過100頁,取10行.
一般地,我們假設每頁N行, 當前是page頁
就需要跳過前 (page-1)*N 行, 再取N行, 在mysql中, limit offset,N來實現
在mongo中,用skip(), limit()函數來實現的

如 var mycursor = db.bar.find().skip(9995);
則是查詢結果中,跳過前9995行

遊標

查詢第901頁,每頁10條
則是 var mytcursor = db.bar.find().skip(9000).limit(10);

遊標

通過cursor一次性得到所有數據, 並返回數組.
例:

var cursor = db.goods.find();
printjson(cursor.toArray()); //看到所有行
printjson(cursor.toArray()[2]); //看到第2行

注意: 不要隨意使用toArray()
原因: 會把所有的行立即以對象形式組織在內存裏.
可以在取出少數幾行時,用此功能.

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章