首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何根据其他集合筛选集合文档?

如何根据其他集合筛选集合文档?
EN

Stack Overflow用户
提问于 2022-01-12 07:54:15
回答 1查看 191关注 0票数 0

我想为我的casesusers的mongo集合创建一个控制器。我希望筛选具有不与cases集合中的user关联的userName支柱的Users。我想用有问题的res(有问题的caseDocs )向客户端发送usersNames池。

下面是我一直在用的东西:

代码语言:javascript
复制
const noUserFuncController = async (res, res) => {
  const cases = await CaseFile.find({})
  const noUsersarr = []
   cases.forEach(async caseDoc => {
    const usr = await Users.findOne({ userName: caseDoc.user })
    if (!usr) {
      noUsers.push(caseDoc)
    }
  })
  res.json(noUsersarr)
}

如有任何意见,我们将不胜感激。

谢谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-01-12 08:39:19

您可以尝试使用$lookup阶段的聚合查询来连接用户信息,如果用户响应为空[],则使用$match阶段进行匹配。

代码语言:javascript
复制
const noUserFuncController = async (res, res) => {

  const noUsersarr = await CaseFile.aggregate([
    {
      $lookup: {
        from: "users", // confirm your collection name here
        localField: "user",
        foreignField: "userName",
        as: "user"
      }
    },
    { $match: { user: [] } }
  ]);

  res.json(noUsersarr);

}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70678008

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档