我有一个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和unitIduserId: 5212bf3869bf351223000002
unitId: 521160695483658217000001
点符号版本返回错误的数组条目(得分为17的数组),$ elemMatch返回正确的条目(得分为33的条目)。那是为什么?
答案 0 :(得分:3)
$elemMatch
与点符号的逻辑不同。 $elemMatch
需要相同的嵌套元素才能拥有值。使用点表示法允许任何嵌套元素具有值。因此,您会看到不同的结果,因为查询逻辑不同。