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}
}
)
这将汇总集合中现有结构上所有文档中的所有注释
要考虑的两件事是,在这个设计中,基本上把“数据”放在“密钥”的值中,并创建出非常难于“查询”的文档路径。当数据存在于密钥中时,它不能被索引,这将导致应用程序使用量增长时的性能不佳。
另一个需要考虑的问题是,您需要“代码”来处理大多数查询需求,无论是客户端还是服务器端,在大多数情况下,标准查询运算符或内置聚合将做得更好因此,您可以使用已显示的代码,但现在确实要进行更改,因为随着应用程序中的所有内容变慢,您迟早要进行更改。您必须检索文档并在客户端计算子对象的键。它可能不是一个有用的模式,因此如果您无法更改它,那将是不幸的。