繁体   English   中英

mongodb:使用$ in运算符的collection.find不返回任何内容

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM