gpt4 book ai didi

mongodb - 从嵌入式数组中获取元素数作为响应 mongoDB

转载 作者:可可西里 更新时间:2023-11-01 10:43:54 27 4
gpt4 key购买 nike

请参阅以下文档:

{
"assetId": ObjectId("5214817cccf3d82198561444"),
"entityType": "MOVIE",
"lastUpdate": NumberLong(1392034838964),
"name": "testMovie",
"resources": [
{
"jobId": ObjectId("52f8c302056f0728d16951f6"),
"lastModifiedTime": NumberLong(1392034563729),
"name": "testMovie",
"status": "ERROR",
"type": "IMAGE_3_2"
},
{
"jobId": ObjectId("52f8c416056f0728d16951fd"),
"lastModifiedTime": NumberLong(1392034838964),
"name": "testMovie",
"status": "ERROR",
"type": "IMAGE_3_1"
}
],
"sandBoxId": "52146e1bccf26997695ca9c0",
"sandboxName": "test"
}

我正在尝试弄清楚如何编写一个查询,该查询将按“类型”响应“资源”数组中的元素数量。

例如(我会用伪代码而不是 mongo 查询来写):匹配 assetId:5214817cccf3d82198561444 其中 resource.type=IMAGE_3_1&IMAGE_3_2

这种情况下的响应应该是:

 {
"jobId": ObjectId("52f8c302056f0728d16951f6"),
"lastModifiedTime": NumberLong(1392034563729),
"name": "testMovie",
"status": "ERROR",
"type": "IMAGE_3_2"
},
{
"jobId": ObjectId("52f8c416056f0728d16951fd"),
"lastModifiedTime": NumberLong(1392034838964),
"name": "testMovie",
"status": "ERROR",
"type": "IMAGE_3_1"
}

我想出了如何从数组中获取单个元素作为响应,而不是元素的数量。

*再次抱歉伪代码

最佳答案

要从数组内部获取多个结果,请使用聚合和 $unwind .

db.collection.aggregate([
{$unwind: "$resources"},
{$match: { "resources.type": {$in :["IMAGE_3_1", "IMAGE_3_2"]}} },
{$project: {_id: 0, resources: 1} }
])

可选地 $match first 以及将在聚合中处理的文档限制为仅包含匹配项的文档。 $project 阶段可以是您的结果需要的任何内容。

关于mongodb - 从嵌入式数组中获取元素数作为响应 mongoDB,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21687055/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com