gpt4 book ai didi

MongoDB:基于另一个集合从一个集合中进行条件选择

转载 作者:行者123 更新时间:2023-12-02 00:39:15 25 4
gpt4 key购买 nike

我是 MongoDB 的新手,需要帮助根据另一个集合的数据对一个集合进行选择或某种左连接。

我有两个集合,动物和膳食,我想获取在特定日期(比如 20171001)之后最后一次注册膳食的动物,以确定该动物是否仍然活跃。

collection animals:
{
name: mr floof,
id: 12345,
lastMeal: abcdef
},
{
name: pluto,
id: 6789,
lastMeal: ghijkl
}

collection meals:
{
id: abcdef,
created: 20171008,
name: carrots
},
{
id: ghijkl,
created: 20170918,
name: lettuce
}

因此在这种情况下查询的预期输出将是:

{
name: mr floof,
id: 12345,
lastMeal: abcdef
}

因为 Floof 先生在 20171008 吃完最后一餐,即在 20171001 之后。

希望我说得够清楚,但如果不清楚,请不要犹豫。

最佳答案

您可以尝试下面的聚合查询。

db.animals.aggregate([ [
{
"$lookup": {
"from": "meals",
"localField": "lastMeal",
"foreignField": "id",
"as": "last_meal"
}
},
{
"$unwind": "$last_meal"
},
{
"$match": {
"last_meal.created": {
"$gt": 20171001
}
}
}
])

更多信息 here .

您可以在 $match 阶段之后使用带排除的 $project 来格式化响应以排除连接的字段。像 { $project: {"last_meal":0} }

这样的东西

关于MongoDB:基于另一个集合从一个集合中进行条件选择,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47752429/

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