查找数组中所有元素都具有特定值的文档

2023-12-19

这基本上是一个简单的问题,但我找不到它的查询函数。

示例集合:

{
  _id: 1,
  foo: [
    { bar: 9 },
    { bar: 16 }
  ]
}

{
  _id: 2,
  foo: [
    { bar: 9 },
    { bar: 9 },
    { bar: 9 }
  ]
}

示例输出:

{
  _id: 2,
  foo: [
    { bar: 9 },
    { bar: 9 },
    { bar: 9 }
  ]
}

因为这是唯一一个每个 foo.bar = 9 的文档。

我正在寻找的查询:

“查找本文档中每个 foo.bar 的 foo.bar = 9 的所有文档。”

或者我是否需要类似“查找所有不存在的文档(foo.bar!= 9)”?

先感谢您!


db.c.find({
    "foo.bar" : {
        $exists : true
    },
    "foo" : {
        $not : {
            $elemMatch : {
                "bar" : {
                    $ne : 9
                }
            }
        }
    }
});
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

查找数组中所有元素都具有特定值的文档 的相关文章

随机推荐