mongodb - 查询Mongo DB中带条件的子元素个数
问题描述
我是 Mongo DB 的新手,希望对以下查询任务有所帮助。
我有一组如下所示的文档:
{
"field_1" : {
"subfield_1" : {
"subsubfield_1" : "true",
"subsubfield_2" : "false",
"subsubfield_3" : "true"
},
"subfield_2" : "sf2"
},
"field_2" : {
"subfield_1" : {
"subsubfield_1" : "true",
"subsubfield_2" : "false"
},
"subfield_2" : "sf2"
},
"field_3" : {
"subfield_1" : {
"subsubfield_1" : "true",
"subsubfield_2" : "false",
"subsubfield_3" : "false"
},
"subfield_2" : "sf2"
}
}
而且我正在尝试查询,以便我为集合中的每个元素(1)准确指定要返回的字段(在这种情况下subfield_1
,和subfield_2
,以及,(2)subfield_1
仅返回元素的计数true
。所以我想要输出看起来像:
{
{
"subfield_1" : 2,
"subfield_2" : "sf2"
},
{
"subfield_1" : 1,
"subfield_2" : "sf2"
},
{
"subfield_1" : 1,
"subfield_2" : "sf2"
}
}
我一直在尝试这段代码,但这只给了我subfield_1
每个元素的条目数:
db.getCollection('myCollection').aggregate(
{
$match: {<some other condition>}
},
{
$project: {
subfield_2: 1,
subfield_1: {'$size': '$subfield_1'}
}
}
)
提前致谢!
解决方案
您需要运行$objectToArray将嵌套结构转换为键和值数组,然后使用$unwind为每个子文档获取单独的文档。$objectToArray
然后你可以运行另一个$filter来只获取true
值:
db.collection.aggregate([
{
$project: {
doc: { $objectToArray: "$$ROOT" }
}
},
{
$unwind: "$doc"
},
{
$match: { $expr: { $ne: [ "$doc.k", "_id" ] } }
},
{
$project: {
_id: 0,
subfield_1: { $size: { $filter: { input: { $objectToArray: "$doc.v.subfield_1" }, cond: { $eq: [ "$$this.v", "true" ] } } } },
subfield_2: "$doc.v.subfield_2"
}
}
])
推荐阅读
- javascript - 如何从对象内部类名中获取 id 值?
- python - POST 构建到 TeamCity 队列
- python - 如何对一组行进行排序?
- python - Python 方法位置 args 故障排除
- rdf - RMLStreamer 函数 grel:array_join 产生不一致的结果
- python - 类型错误:scipy.interpolate.interp1d 中的“str”和“float”实例之间不支持“<”
- javascript - 使用模式行创建角垫表设计
- python - 边缘检测最小线长?
- javascript - TypeError:页面重新呈现后无法读取未定义的属性
- mongodb-compass - 在 compass 1.28.1 上为聚合管道创建视图