gpt4 book ai didi

mongodb - 点符号与 $elemMatch

转载 作者:IT老高 更新时间:2023-10-28 13:29:14 25 4
gpt4 key购买 nike

我有一个 unitScores 集合,其中每个文档都有一个 id 和一个文档数组,如下所示:

"_id": ObjectId("52134edd5b1c2bb503000001"),
"scores": [
{
"userId": ObjectId("5212bf3869bf351223000002"),
"unitId": ObjectId("521160695483658217000001"),
"score": 33
},
{
"unitId": ObjectId("521160695483658217000001"),
"userId": ObjectId("5200f6e4006292d308000008"),
"score": 17
}
]

我有两个查找查询:

_id:new ObjectID(scoreId)
"scores.userId":new ObjectID(userId)
"scores.unitId":new ObjectID(unitId)

_id:new ObjectID(scoreId)
scores:
$elemMatch:
userId:new ObjectID(userId)
unitId:new ObjectID(unitId)

我希望他们给出相同的结果,但使用输入的 userId 和 unitId

userId: 5212bf3869bf351223000002
unitId: 521160695483658217000001

点表示法版本返回错误的数组条目(得分:17),$elemMatch 返回正确的条目(得分:33)。这是为什么呢?

最佳答案

$elemMatch 与点符号的逻辑不同。 $elemMatch 需要相同的嵌套元素才能具有值。使用点表示法允许任何嵌套元素具有值。因此,由于查询逻辑不同,您会看到不同的结果。

关于mongodb - 点符号与 $elemMatch,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18335248/

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