当前位置: 首页 > 面试题库 >

在填充猫鼬后查找

狄峻熙
2023-03-14
问题内容

我在用猫鼬填充后无法通过在文档内部匹配的值来查询文档。

我的架构是这样的:

var EmailSchema = new mongoose.Schema({
  type: String
});

var UserSchema = new mongoose.Schema({
  name: String,
  email: [{type:Schema.Types.ObjectId, ref:'Email'}]
});

我想让所有用户拥有例如类型为“ Gmail”的电子邮件。

以下查询返回空结果:

Users.find({'email.type':'Gmail').populate('email').exec( function(err, users)
    {
      res.json(users);
    });

我不得不像这样过滤JS中的结果:

users = users.filter(function(user)
        {
          for (var index = 0; index < user.email.length; index++) {
            var email = user.email[index];
            if(email.type === "Gmail")
            {
              return true;
            }
          }
          return false;
        });

有没有办法从猫鼬直接查询类似的东西?


问题答案:

@Jason Cust 已经很好地解释了它-
在这种情况下,通常最好的解决方案是更改架构,以防止Users通过存储在单独集合中的文档的属性进行查询。

不过,这是我能想到的最佳解决方案,不会强迫您这样做(因为您在评论中说不能)。

Users.find().populate({
  path: 'email',
  match: {
    type: 'Gmail'
  }
}).exec(function(err, users) {
  users = users.filter(function(user) {
    return user.email; // return only users with email matching 'type: "Gmail"' query
  });
});

我们在这里所做的只是填充emails匹配其他查询(调用中的match选项.populate()),否则文档中的email字段Users将设置为null

剩下的全部都.filter放在返回的users数组上,就像在您最初的问题中一样-仅使用更简单,非常通用的检查。如您所见-
email存在或不存在。



 类似资料:
  • 问题内容: 一般而言,我对Mongoose和MongoDB还是很陌生,所以我很难确定是否可以进行以下操作: 有更好的方法吗? 编辑 如有任何混淆,我们深表歉意。我想做的是获取所有包含有趣标签或政治标签的商品。 编辑 没有where子句的文档: 使用where子句,我得到一个空数组。 问题答案: 对于大于3.2的现代MongoDB,您可以在大多数情况下用作替代。这也有实际上做加盟,而不是什么“在服务

  • 问题内容: 我无法手动或自动在新保存的对象上填充创建者字段……我能找到的唯一方法是重新查询我已经想要做的对象。 这是设置: 这是我拉头发的地方 编辑:最新的猫鼬解决了此问题并添加了填充功能,请参见新的接受的答案。 问题答案: 您应该能够使用模型的填充函数来执行此操作:http : //mongoosejs.com/docs/api.html#model_Model.populate 在书籍的保存处

  • 问题内容: 我使用Mongoose.js,无法解决3级层次结构文档的问题。 有2种方法可以做到。 首先 -没有裁判。 我需要出示C记录。仅知道_id的C,如何填充/找到它? 我曾尝试使用: 但是我不知道如何从returnet得到一个对象,我只需要c对象。 其次, 如果使用裁判: 如何填充所有B,C记录以获取层次结构? 我试图使用这样的东西: 但是它将为single_c.title返回undefin

  • 问题内容: 假设以下3个模型: 当我查询汽车时,我可以填充零件: 猫鼬是否有办法在所有汽车的嵌套零件对象中填充otherIds。 我可能可以遍历每辆车并尝试填充: 问题是我必须使用一个像async这样的库来对每个对象进行填充调用,然后等到所有操作完成后再返回。 可以在不循环所有汽车的情况下做? 问题答案: 更新: 请参阅以获取在Mongoose 4中添加的更紧凑的版本。摘要如下: 猫鼬3及以下:

  • 问题内容: 如何在示例文档中填充“组件”: 这是我的JS,可从Mongoose获取文档: 问题答案: 猫鼬4.5支持此 您可以加入不止一个深层次

  • 问题内容: 我不确定如何填充下面的示例架构,甚至可能。引用可以在如下所示的对象内吗?如果可以,您将如何填充?例如? 还是我必须有两个单独的数组来定位和计数,如下所示: 我觉得第一个解决方案是最好的,但是我不确定如何在Mongoose中使用它。 非常感谢您的帮助! 问题答案: 第一种解决方案是可能的。 猫鼬目前有限制(在这里看到这张票)填充嵌入文档的多层次,不过 是 在一个文档中了解嵌套的路径非常好