您好,登錄后才能下訂單哦!
MongoDB 2.6 兼容性改變 -- db.collection.aggregate()改變
描述
db.collection.aggregate()方法在mongo shell中,默認返回結果集的游標。這個修改使得聚合管道返回任何大小的結果集,需要游標遍歷來訪問結果集。例如:
var myCursor = db.orders.aggregate( [ { $group: { _id: "$cust_id", total: { $sum: "$price" } } } ] ); myCursor.forEach( function(x) { printjson (x); } );
之前的版本返回帶有字段result的單一文檔,它包含了結果集的一個數組,受限于BSON文檔大小限制。在MongoDB之前的版本訪問結果集需要訪問result字段,并遍歷數組。例如:
var returnedDoc = db.orders.aggregate( [ { $group: { _id: "$cust_id", total: { $sum: "$price" } } } ] ); var myArray = returnedDoc.result; // access the result field myArray.forEach( function(x) { printjson (x); } );
解決方案
修改腳本,當前期待db.collection.aggregate()返回一個文檔帶result數組字段,替換為處理游標。
可以參考
聚合增強
db.collection.aggregate()
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。