考虑将来切换到 DynamoDB,但要确保我的文档在 1KB 以下,因为它们按 KB 收费。有没有一种快速的方法可以知道集合中的文档有多大?
问问题
15046 次
1 回答
19
作为一般指南,您可以使用集合报告的值检查集合collname中文档的平均大小:avgObjSize
stats()
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 回答