考虑将来切换到DynamoDB,但是要确保我的文档低于1KB,因为它们按KB收费。有没有快速的方法来了解文档在集合中的大小?
答案 0 :(得分:12)
作为一般指南,您可以使用集合avgObjSize
报告的stats()
值检查集合 collname 中文档的平均大小:
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表示形式,它与在其他数据库中表示相同数据所需的大小不同。