首页 > 解决方案 > Mongoose:使用 _id 以外的字段填充路径

问题描述

默认情况下,mongoose/mongo 将使用该_id字段填充路径,并且似乎无法将其更改_id为其他内容。

这是我的两个与一对多关系相关的模型:

const playlistSchema = new mongoose.Schema({
  externalId: String,
  title: String,
  videos: [{
    type: mongoose.Schema.Types.ObjectId,
    ref: 'Video',
  }],
});

const videoSchema = new mongoose.Schema({
  externalId: String,
  title: String,
});

videos通常,在查询播放列表时,您只会使用填充.populate('videos'),但在我的情况下,我想使用该externalId字段而不是默认的_id. 那可能吗?

标签: javascriptnode.jsmongodbmongooseschema

解决方案


据我所知,目前使用 mongoose 实现此目的的方法是使用virtuals。填充虚拟时,您可以将localFieldand指定为foreignField 您想要的任何内容,因此您不再被绑定到默认值_idas foreignField。更多细节在这里

对于您的问题中描述的场景,您需要向 中添加一个虚拟playerlistSchema,如下所示:

playlistSchema.virtual('videoList', {
  ref: 'Video', // The model to use
  localField: 'videos', // The field in playerListSchema
  foreignField: 'externalId', // The field on videoSchema. This can be whatever you want.
});

现在,每当您查询播放器列表时,您都可以填充videoList虚拟以获取引用的视频文档。

PlaylistModel
  .findOne({
    // ... whatever your find query needs to be
  })
  .populate('videoList')
  .exec(function (error, playList) {
    /* if a playList document is returned */
    playList.videoList; // The would be the populated array of videos
  })

推荐阅读