![](/img/trans.png)
[英]node.js mongodb - collection.find().toArray(callback) - callback doesn't get called
[英]mongodb: collection.find with $in operator doesn't return anything
我有一个mongodb查询问题。
目前我表演
collection.find({ "history.data": { "key": "paymentStatus", "value": {
$in: ["fail1", "fail2", "fail3", "fail4", "fail5", "fail6", "fail7",
"blocked"] } } })
但它没有返回我想要的对象,实际上它返回了一个空数组。
对象的结构如下:
{history: {time: ... , data: [ {key: "paymentStatus", value: "fail1"}, ... ] }}
这是嵌套mongodb find查询的正确语法吗?
您查询的正确语法如下:
collection.find({
"history.data": {
$elemMatch: {
"key":"paymentStatus",
"value": { $in: ["fail1","fail2","fail3","fail4","fail5","fail6","fail7", "blocked"]}
}
}
})
如果您只有一个查询条件而不是两个,则可以编写以下内容:
collection.find({ "history.data.key":"paymentStatus"})
但是根据您的情况,您有两个查询条件,因此您需要使用$ elemMatch。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.