我正面临着一个奇怪的行为与 mongo-shell und Spring Data Mongodb
这是我的示例查询:
> db.substances.find({"precursor.mass": {$gte:159.9900,$lte:160.0100}}).count()
6
所以我想找到给定范围内(加/减)的质量值。在本例中,输入为 160 +/- 0.01。
以下是六个结果中的两个。第一个还可以,但我无法解释和理解为什么找到第二个结果。
{
"_id" : ObjectId("524bfe80729458abfd7698a5"),
"exactMass" : 159.1259,
"nominalMass" : 159,
"molarMass" : 159.22,
"status" : 1,
"decompositions" : [ ],
"precursor" : [
{
"mass" : 160,
"ion" : "+H",
"charge" : "+",
"fragments" : [
55,
83,
124,
97,
69,
142
]
}
],
}
{
"_id" : ObjectId("524bfe80729458abfd7695be"),
"exactMass" : 159.068414,
"nominalMass" : 159,
"molarMass" : 159.19,
"status" : 0,
"decompositions" : [ ],
"precursor" : [
{
"mass" : 158.0611,
"ion" : "-H",
"charge" : "-",
"fragments" : [ ]
},
{
"mass" : 160.0756,
"ion" : "+H",
"charge" : "+",
"fragments" : [ ]
}
],
}
我忽略了什么?我想我使用了错误的查询?
我的目标是找到任何前体质量在给定值+/-公差之间的所有物质。
来自 mongo doc on find():
因此如果字段包含数组,并且查询具有多个条件 运算符,如果单个数组,则整个字段将匹配 元素满足条件或数组元素的组合满足 条件。
,由于{"mass" : 158.0611}
匹配第二个查询条件(小于 160.0100),并且{"mass" : 160.0756}
匹配第一个查询条件(大于 159.9900),因此整个数组匹配。
您正在寻找的是$elemMatch:
db.substances.find({
"precursor": {
$elemMatch: {
mass: { $gt:159.9900, $lt:160.0100 }
}
}
}).pretty()