好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > MongoDB快速翻頁的方法

MongoDB快速翻頁的方法

熱門標簽:南京400電話怎樣辦理 企業智能外呼系統價格多少 智能電銷機器人銷售話術 徐州ai電銷機器人原理 福州電銷機器人源代碼 沈陽營銷電銷機器人招商 高德地圖標注商戶位置 機器人外呼系統軟件存在問題 兗州電話外呼營銷系統

翻閱數據是MongoDB最常見的操作之一。一個典型的場景是需要在你的用戶界面中顯示你的結果。如果你是批量處理的數據,同樣重要的是要讓你的分頁策略正確,以便你的數據處理可以規模化。

接下來,讓我們通過一個例子來看在MongoDB中翻閱數據的不同方式。在這個例子中,我們有一個CRM數據庫的用戶數據,我們需要通過翻閱瀏覽和在同一時間顯示10個用戶。所以實際上,我們的頁面大小是10。下方是我們的用戶文檔的結構:

{

  _id,

  name,

  company,

  state

}

方法一:Using skip() 和 limit()

MongoDB本身支持分頁操作使用 skip() 和 limit() 指令。skip(n)指令告訴MongoDB,它應該跳過“n”結果和limit(n)指令指示MongoDB,它應該限制結果長度為“n”結果。通常情況下,你將使用 skip() 和 limit() 指令,但為了說明情況,我們提供了控制臺命令,這樣也能達到相同的結果。同時,為了代碼比較簡潔,限制檢查代碼被排除在外。

//Page 1

db.users.find().limit (10)

//Page 2

db.users.find().skip(10).limit(10)

//Page 3

db.users.find().skip(20).limit(10)

........

一般來說,檢索頁面n,代碼是這樣的:

db.users.find().skip(pagesize*(n-1)).limit(pagesize)
然而,隨著數據的大小增加,這種方法出現嚴重的性能問題。其原因是在每次執行查詢時,建立了完整的結果集,那么服務器必須從收集的開始走到指定的偏移量。當偏移量增加時,這一過程會變得越來越慢。同時,這個過程沒有有效地使用索引。所以,當你有較小的數據集時,典型的“skip() ”和“ limit() ”的方法是有用的。如果您正在使用大數據集,您需要考慮其他方法。

方法二:Using find() 和limit()

以前的方法不能很好擴展其原因是skip() 命令。因此,本節的目標是實現分頁不使用skip()命令。為此,我們將利用在存儲數據中的自然順序,比如時間戳或文檔中存儲的標識。

在這個例子中,我們將使用“_id”存儲每個文檔。“_id”是一個MongoDB 的ObjectID結構,即 12 字節結構包含了時間戳、機械加工、進程標識符、計數器等。總體思路如下 :

檢索當前頁中的最后一個文檔 _id
在下一個頁面檢索文件大于此”_id”

//Page 1

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

//Find the id of the last document in this page

last_id = ...

//Page 2

users = db.users.find({'_id'> last_id}). limit(10);

//Update the last id with the id of the last document in this page

last_id = ...

這種方法利用內在的規則存在_id字段。也因為“_id”字段是默認的查找操作,它是非常好的性能指標。如果你使用的字段沒有被索引,那么你在操作中會受到困擾,所以確保字段被索引是非常重要的。

同樣,如果你希望數據按照特定順序進行排序分頁的話,那么你還可以使用sort()條款與上述技術。重要的是要確保排序過程是利用索引來獲得最佳性能。您可以使用.explain()后綴來查詢。

users = db.users.find({'_id'> last_id}). sort(..).limit(10);

//Update the last id with the id of the last document in this page

last_id = ...

以上就是MongoDB快速翻頁的方法,希望能給大家一個參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • php中文本數據翻頁(留言本翻頁)
  • 如何編寫翻頁函數?
  • 點圖片上一頁下一頁翻頁效果
  • PHP 翻頁 實例代碼
  • PHP 長文章分頁函數 帶使用方法,不會分割段落,翻頁在底部
  • php實現的仿阿里巴巴實現同類產品翻頁
  • 在圖片上顯示左右箭頭類似翻頁的代碼
  • 解析Android中實現滑動翻頁之ViewFlipper的使用詳解
  • 通過MySQL優化Discuz!的熱帖翻頁的技巧
  • PHP翻頁跳轉功能實現方法

標簽:景德鎮 本溪 昭通 鶴崗 吉安 丹東 大理 邯鄲

巨人網絡通訊聲明:本文標題《MongoDB快速翻頁的方法》,本文關鍵詞  MongoDB,快速,翻頁,的,方法,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MongoDB快速翻頁的方法》相關的同類信息!
  • 本頁收集關于MongoDB快速翻頁的方法的相關信息資訊供網民參考!
  • 推薦文章