gpt4 book ai didi

javascript - 复杂的 Mongo 查询,同时检查多个属性

转载 作者:行者123 更新时间:2023-11-30 09:56:23 24 4
gpt4 key购买 nike

这是我的数据库的样子:

[
{
_id : xxx,
languages : [
{ lang: "French", level: 1 },
{ lang: "English", level: 3 },
{ lang: "Spanish", level: 4 }
]
},
{
_id : yyy,
languages : [
{ lang: "French", level: 5 },
{ lang: "English", level: 2 }
]
}
]

我有那种列表:

[
{
lang : "French",
cmp : "at least",
level : 3
},
{
lang : "English",
cmp : "at most",
level : 2
}
]

我的目标是构建一个查询,在此示例中:

  • 选择法语水平 >=

    的所有用户
  • AND 英语水平 <= 2

  • 选定的用户可以有其他我不关心的语言

换句话说,我想构建一个查询来查找拥有列表中指定的所有语言的每个用户,每种语言都必须匹配级别比较才有效。

这有点难,因为我不习惯 MongoDB 中如此复杂的查询。

目前,我不是在寻找级别比较。我只是查询匹配好语言的用户,无论级别如何,使用 "profile.languages.lang": { $all: languagesArray }languagesArray 列表我在比较的对象列表中使用 .map 获得的字符串。

我的问题是我不知道如何对文档的单个属性/列表指定如此多的约束。当然,我可以提取数据来优化我的搜索,但随着时间的推移,这会非常昂贵,因为我的数据库增长得非常快。

谁能指导我?

谢谢。

最佳答案

Users.find({
$or: [
{
languages: {
$elemMatch: {
lang: 'French',
level: { $gte: 2 }
},
}
},
{
languages: {
$elemMatch: {
lang: 'English',
level: { $lte: 2 }
}
}
}
]
}).fetch();

关于javascript - 复杂的 Mongo 查询,同时检查多个属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33762498/

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