Mongodb 如何获取不在集合中的元素?

Mongodb 如何获取不在集合中的元素?,mongodb,mongoose,mongo-shell,Mongodb,Mongoose,Mongo Shell,假设我有一个集合,{key:1},{key:2},{key:3} 我有一些数组[1,2,3,4,5,6,7] 我想得到集合中没有的元素 在本例中,它将打印4,5,6,7 可能吗?您可以使用$setDifference $group按null,在elem中创建元素数组 $project使用$setDifference 谢谢你的帮助,可以在分组前添加一些过滤器吗? db.collection.aggregate([ { $group: { _id: null,

假设我有一个集合,
{key:1},{key:2},{key:3}

我有一些数组
[1,2,3,4,5,6,7]

我想得到集合中没有的元素

在本例中,它将打印
4,5,6,7


可能吗?

您可以使用
$setDifference

  • $group
    按null,在
    elem
    中创建元素数组
  • $project
    使用
    $setDifference

谢谢你的帮助,可以在分组前添加一些过滤器吗?
db.collection.aggregate([
  {
    $group: {
      _id: null,
      elem: { $push: "$key" }
    }
  },
  {
    $project: {
      elem: { $setDifference: [[1, 2, 3, 4, 5, 6, 7], "$elem"] }
    }
  }
])