如何使用 golang 從 mongo 數據庫中批量獲取記錄?我知道 mongoDB 本身有一個叫做 cursor.batchSize() 的東西,但我試圖找到一個使用 golang 驅動程序的例子。據我所知,golang 庫 mgo 有一個名為 Batch 的函數,但我想弄清楚如何使用它。理想情況下,我正在尋找這樣的東西:const cursor = useDb.collection(mycollection).find().batchSize(10000);for (let doc = await cursor.next(); doc != null; doc = await cursor.next()) { if (doc._id % divisor === 0) { counter++; }}到目前為止我有這樣的事情:err := c.Find(nil).Batch(1).All(&items)但它沒有像預期的那樣工作。鏈接: https://docs.mongodb.com/manual/reference/method/cursor.batchSize/ https://godoc.org/github.com/globalsign/mgo#Query.Batch
1 回答
牧羊人nacy
TA貢獻1862條經驗 獲得超7個贊
指定batchSize()每批響應中要返回的文檔數。你仍然會得到所有的結果。例如,如果返回的文檔總數為 100,而您將批量大小指定為 20,則您將有 1find和 4 個getMore命令從客戶端發送到mongod完成請求。
您可以使用一個小技巧來驗證。使用db.setProfilingLevel(0, 0)mongo shell 將所有內容記錄在日志文件中。執行您的測試應用程序,您將看到find并getMore記錄在日志中。
- 1 回答
- 0 關注
- 352 瀏覽
添加回答
舉報
0/150
提交
取消
