如何解决mongocxx计算集合中的文档数
在shell中,对集合中文档的数量进行计数非常容易且快捷(显然是固定时间)。
> db.my_collection.count()
12345678
>
在C ++中,我尝试这样做:
mongocxx::client client;
mongocxx::database db = MongoInit(client,...);
vector<string> collection_names;
mongocxx::cursor cursor = db.list_collections();
for (const bsoncxx::document::view& doc : cursor) {
string collection_name = doc["name"].get_utf8().value.to_string();
collection_names.push_back(collection_name);
}
bsoncxx::document::view empty_filter;
for (const string& collection_name : collection_names) {
LOG_INFO << collection_name;
mongocxx::collection collection = db[collection_name];
int64_t collection_count = collection.count_documents(empty_filter);
LOG_INFO << collection_name << " " << collection_count;
}
此代码有效,但速度很慢。我做错了什么吗?
解决方法
count
和count_documents
是非常不同的功能。
MongoDB维护有关每个集合的元数据,其中包含存储的文档数。插入文档时,此数字递增;删除文档时,此数字递减。此数字可能与集合不同步,因此应将其视为一个近似值。
count
只是从元数据中读取该数字并将其返回,从而使其能够在恒定时间内完成。
count_documents
函数扫描集合以获取准确的文档计数,而不是元数据中的近似计数。
如果需要快速而不是精确的结果,请使用estimated_document_count
函数。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。