5

考虑将来切换到 DynamoDB,但要确保我的文档在 1KB 以下,因为它们按 KB 收费。有没有一种快速的方法可以知道集合中的文档有多大?

4

1 回答 1

19

作为一般指南,您可以使用集合报告的值检查集合collname中文档的平均大小:avgObjSizestats()

db.collname.stats()

要查找和计算大型文档,您可以使用类似于:

var maxSize = 1024;
var bigDocs = 0;
db.collname.find().forEach(
    function (doc) {
        var docSize = Object.bsonsize(doc);
        if (docSize >= maxSize) {
            bigDocs++;
            print(doc._id + ' is ' + docSize + ' bytes');
        }
    }
)
print("Found " + bigDocs + " documents bigger than " + maxSize + " bytes")

请注意,这两个示例都使用 MongoDB BSON表示,这与在其他数据库中表示相同数据所需的大小不同。

于 2012-09-30T03:17:58.553 回答