Nodejs mongodb获取文档大小而不实际获取游标

时间:2016-01-07 14:24:09

标签: javascript node.js mongodb

我的问题是,如何在不实际提取的情况下获得cursor尺寸(以KB为单位)

我已经检查了很多问题,例如here但我不想获取查询结果以了解 KB 是多少。

我只想要这样的东西:

var MongoClient = require('mongodb').MongoClient,
  test = require('assert');
MongoClient.connect('mongodb://localhost:27017/test', function(err, db) {

  var collection = db.collection('simple_query');

  // Insert a bunch of documents for the testing
  collection.insertMany([{a:1}, {a:2}, {a:3}], {w:1}, function(err, result) {
    test.equal(null, err);

    collection.find(/**SOME QUERY*/).size(function(err, SIZE) {
      test.equal(null, err);
      test.equal(32111351, SIZE); // in bytes or kilobytes whatever
      db.close();
    });
  });
});

1 个答案:

答案 0 :(得分:0)

这样的东西?

var avgSize = db.collectionName.stats().avgObjSize;

// ...

collection.count(/* some query */, function(err, count) {
    var approximateSize = count*avgSize; // This could work for simple database models
}

我知道它并不完美,但这是我找到的最佳方式。