我有一个数据库,它具有这样的结构:
{
"_id" : ObjectId("x"),
"T_K" : 750,
"P_Pa" : 2026500,
"phi" : 1,
"composition" : [
{
"species" : "NC10H22",
"mol_fraction" : 0
},
{
"species" : "NC12H26",
"mol_fraction" : 1
}
],
我的目标是找到具有特定组成的对象(由字段“mol_fraction”给出),假设是0,1。但如果我尝试以下命令:
db.prova.find({"composition.mol_fraction":[0,1]})
它什么也找不到。我该怎么做呢?
请注意,如果我使用以下命令:
db.prova.find({"composition.mol_fraction":0})
它查找"mol_fraction“字段之一等于0的所有对象。
发布于 2019-08-08 03:14:33
设计此查询的方法应该是可以动态传递组合数组。
假设我们在DB中有以下数据:
{
"_id" : ObjectId("5d4b2039cbfa696dcd9924a5"),
"T_K" : 750,
"P_Pa" : 2026500,
"phi" : 1,
"composition" : [
{
"species" : "NC10H22",
"mol_fraction" : 0
},
{
"species" : "NC12H26",
"mol_fraction" : 1
}
]
}
{
"_id" : ObjectId("5d4b20eecbfa696dcd9924a6"),
"T_K" : 712,
"P_Pa" : 2026501,
"phi" : 2,
"composition" : [
{
"species" : "H2",
"mol_fraction" : 0
},
{
"species" : "O",
"mol_fraction" : 1
}
]
}
{
"_id" : ObjectId("5d4b20eecbfa696dcd9924a7"),
"T_K" : 713,
"P_Pa" : 2026502,
"phi" : 2,
"composition" : [
{
"species" : "Na",
"mol_fraction" : 2
},
{
"species" : "H",
"mol_fraction" : 1
},
{
"species" : "CO3",
"mol_fraction" : 4
}
]
}
现在,我们需要搜索:2,1,4
下面的查询可以得到预期的结果:
db.prova.aggregate([
{
$match:{
$expr:{
$eq:[
[2,1,4],
{
$map:{
input:"$composition",
as:"composition",
in:{
$trunc: "$$composition.mol_fraction"
}
}
}
]
}
}
}
]).pretty()
输出:
{
"_id" : ObjectId("5d4b20eecbfa696dcd9924a7"),
"T_K" : 713,
"P_Pa" : 2026502,
"phi" : 2,
"composition" : [
{
"species" : "Na",
"mol_fraction" : 2
},
{
"species" : "H",
"mol_fraction" : 1
},
{
"species" : "CO3",
"mol_fraction" : 4
}
]
}
我们做了什么?
发布于 2019-08-07 23:57:10
您需要操作符$in来执行此操作:
db.prova.find({ "composition.mol_fraction": { $in: [ 0, 1 ] }})
编辑:(按特定顺序搜索)
我不知道MongoDB是否像你在对这个答案的评论中所说的那样提供了“过滤优先级”,但是,如果你需要根据数组中按预定顺序出现的值进行过滤,你可以这样做:
db.prova.find({
"composition.0.mol_fraction": 0,
"composition.1.mol_fraction": 1,
})
这里的缺点是,如果需要查找序列0,1,2 (或更长),则需要根据值列表的大小动态构建查询。
同样,这是可行的,但我不知道是否有更复杂的方法来做到这一点。
https://stackoverflow.com/questions/57397962
复制相似问题