Javascript MongoDB统计对象中的对象

Javascript MongoDB统计对象中的对象,javascript,mongodb,mapreduce,mongodb-query,aggregation-framework,Javascript,Mongodb,Mapreduce,Mongodb Query,Aggregation Framework,我想知道物体内部有多少元素 我的收藏如下: {"_id": 'xxx', "comments":{ "_id_ab6666djdkjd": { "text": "my text" }, "_id_ab6dee": { "text": "my text2" } } }, {"_id": 'xxx', "comments":{ "_id_ab6666dddjdkjd

我想知道物体内部有多少元素

我的收藏如下:

{"_id": 'xxx', 
 "comments":{
       "_id_ab6666djdkjd": { 
           "text": "my text"
        },
        "_id_ab6dee": { 
           "text": "my text2"
        }
  }
},
{"_id": 'xxx', 
 "comments":{
       "_id_ab6666dddjdkjd": { 
           "text": "my text"
        }
     }
}
我想计算所有文档中的注释数?我知道在注释中使用数组是最好的做法,但我不能改变模式设计

最好的,
洛伦佐

去找你的老板,告诉他们我告诉他们“改变设计”。这是你应该告诉他们的帖子,我告诉他们

这个设计很糟糕,如果不在客户端或服务器上使用代码进行处理,就无法使用它。在服务器上,这意味着JavaScript解释,其中所需的处理和缺乏能够更好地使用MongoDB的内置功能

理想情况下,您的文档应如下所示:

{
“评论”:[
{u id:“ab6666djdkjd”,“text:“my text”}
{u id:“ab6dee”,“text:“my text2”}
],
“评论计数”:2
},
{
“评论”:{
{u id:“ab6666dddjdkjd”,“text:“my text”}
],
“评论计数”:1
}
因此,不仅结构为数组,而且保持数组的“长度”,这很容易使用运算符和and运算来实现

最简单的查询如下:

db.collection.aggregate([
{“$组”:{
“_id”:空,
“计数”:{“$sum”:“$commentCount”}
}}
])
因此,如果没有支持它的结构,您将不得不运行速度慢得多的处理器:

db.collection.mapReduce(
函数(){
emit(null,Object.keys(this.comments.length);
},
功能(键、值){
返回Array.sum(值);
},
{
“out”:{“inline”:1}
}
)
这将汇总集合中现有结构上所有文档中的所有注释

要考虑的两件事是,在这个设计中,基本上把“数据”放在“密钥”的值中,并创建出非常难于“查询”的文档路径。当数据存在于密钥中时,它不能被索引,这将导致应用程序使用量增长时的性能不佳。

另一个需要考虑的问题是,您需要“代码”来处理大多数查询需求,无论是客户端还是服务器端,在大多数情况下,标准查询运算符或内置聚合将做得更好


因此,您可以使用已显示的代码,但现在确实要进行更改,因为随着应用程序中的所有内容变慢,您迟早要进行更改。

您必须检索文档并在客户端计算子对象的键。它可能不是一个有用的模式,因此如果您无法更改它,那将是不幸的。