在Mongoose中使用“ Ref”获取mongo数据时出现问题

时间:2019-08-26 20:02:48

标签: javascript node.js mongodb mongoose graphql

嘿,我一直在尝试graphql,所以有一种情况我卡在“ Ref”部分中……假设我也有下面定义的模式

User.js

const userschema = new Schema({
  email: {
    type: String,
    required: true
  },
  createdevents: [
    {
      type: Schema.Types.ObjectId,
      ref: "Event"
    }
  ]
});
module.exports = mongoose.model("User", userschema);

然后是events.js

const eventschema=new Schema({
    title:{
        type:String,
        required:true
    },
    price:{
        type:Number,
        required:true
    },
    creator:{
        type:Schema.Types.ObjectId,
        ref:'User'
    }
})
module.exports=mongoose.model('Event',eventschema)

因此,当我使用事件数据时,我尝试通过以下populate()方法获取用户属性

events: () => {
        return Event.find().populate('creator').then(result => {
          return result.map(e => {
            return { ...e._doc, _id: e._doc._id.toString() };
          });
        });
      }

所以我现在可以访问所有用户属性,但是如果我需要访问User.js中“ createdevents”内部的事件字段怎么办,这意味着我需要再运行一次填充方法,以便我可以获取所有事件属性存储在“ createdevents”内部,但下面带有相同的代码

简而言之,我还是需要在

中另外应用一种填充方法
 events: () => {
                return Event.find().populate('creator').then(result => {
                  return result.map(e => {
                    return { ...e._doc, _id: e._doc._id.toString() };
                  });
                });
              }

以便我可以在createdevents内的所有事件属性中再占一遍

我需要的订单就像

事件(创建者)->使用填充(已实现所有用户属性)->现在在User.js中,我必须再次应用填充以实现所有事件属性

抱歉,这听起来很奇怪,我无法解释 我认为它类似于多级人口

现在,如果我运行查询

query{
  events{
    title
    creator{
      _id
      email
      createdevents{
        _id
      }
    }
  }
}

我得到

{
  "data": {
    "events": [
      {
        "title": "asd",
        "creator": {
          "_id": "5d64354bfd7bb826a9331948",
          "email": "test@test.com",
          "createdevents": [
            {
              "_id": "5d6435a78150062703df70ff"
            },
            {
              "_id": "5d6435ab8150062703df7101"
            },
            {
              "_id": "5d6435cc8150062703df7102"
            }
          ]
        }
      }
    ]
  }
}

这很好,但是我只能获取事件的_id,我需要获取所有可以通过填充方法guess实现的属性

1 个答案:

答案 0 :(得分:1)

您可以通过以下方式填充多个级别:

Event.find()
     .populate({
       path: 'creator',
       populate: { path: 'createdevents' }
     });