我有一个名为index的数据库只有一个名为student的集合。
当我触发查询db.students.find({}).count()
它显示了1000000个文档。
但是当我使用db.stats()时它会显示如下结果: -
{
"db" : "index",
"collections" : 3,
"objects" : 1000004,
"avgObjSize" : 59.95997216011136,
"dataSize" : 59960212,
"storageSize" : 87420928,
"numExtents" : 14,
"indexes" : 1,
"indexSize" : 32458720,
"fileSize" : 520093696,
"nsSizeMB" : 16,
"ok" : 1
}
3个收藏如何?
对象1000004的数量是预期的4个额外费用吗?
最后我做了db.getCollectionNames()
它显示[ "student", "system.indexes" ]
什么是system.indexes
?
请有人详细说明吗?
我是mongo世界的新手。
答案 0 :(得分:8)
当用户首次在数据库中存储数据或显式创建数据库时,会创建两个集合。
第一个,system.indexes
包含有关数据库各种集合中定义的索引的信息。您甚至可以使用
db.system.indexes.find()
隐藏的一个system.namespaces
包含有关数据库的一些元数据,实际上是从数据库管理角度看所有现有实体的名称。
虽然没有显示,但你仍然可以访问它:
db.system.namespaces.find()
警告:不要弄乱他们中的任何一个。您的数据库很可能无法使用。你被警告了!
甚至可能超过这两个。请阅读System Collections in the MongoDB docs了解详情。
实际上,如果您尝试访问如上所示的系统数据库,那么这个变得非常容易。在名为foobardb
的数据库中,集合foo
和_id
上的默认索引,查询system.indexes
将得到这样的结果(美化):
{
"v" : 1,
"key" : {
"_id" : 1
},
"name" : "_id_",
"ns" : "foobardb.foo"
}
请注意,这是一个单独的文档。第二个查询的美化输出如下所示:
{ "name" : "foobardb.foo" }
{ "name" : "foobardb.system.indexes" }
{ "name" : "foobardb.foo.$_id_" }
在这里,我们有三个文件。所以我们在元数据中有4个额外的文档。