gpt4 book ai didi

MongoDB 一一

转载 作者:可可西里 更新时间:2023-11-01 10:04:30 24 4
gpt4 key购买 nike

我想为我指定的每个类别 ID 检索最新帖子的 mongo 选择器。

这是 forumTopics 集合中对象的示例:

{
_id: ...,
createdTime: [unix epoch timestamp],
catagory: "someid"
}

在我的代码中,我有一组我想要的类别 ID:

catagories = ["someid", "sometherid"]

我可以像这样获取类别的帖子:

forumTopics.find {catagory: {$in: catids}}

我的问题是如何为每个类别只获取一个主题对象,获取的对象是具有最大 createdTime 的对象。我知道如何以 1 的限制获取,但我不确定如何为 $in 中的每个类别获取一个。

最佳答案

您可以使用聚合框架来做到这一点:

forumTopics.aggregate( [
{ $match: { catagory: {$in: catids} } },
{ $sort: { createdTime: 1 } },
{ $group: {
_id: "$catagory",
forumTopicId: {
$last: "$_id"
}
}
}
] )

关于MongoDB 一一,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21735152/

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