Пн goose: заполнить путь, используя поле, отличное от _id - PullRequest
1 голос
/ 07 апреля 2020

По умолчанию mongoose / mon go заполнит путь, используя поле _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. Это возможно?

1 Ответ

0 голосов
/ 08 апреля 2020

Насколько я знаю, способ достичь этого с помощью mon goose в настоящее время заключается в использовании virtuals . При заполнении виртуалов вы можете указать localField и foreignField для чего хотите, чтобы вы больше не привязывались к стандартному _id как foreignField. Подробнее об этом здесь .

Для сценария, описанного в вашем вопросе, вам необходимо добавить виртуальный объект к playerlistSchema, что-то вроде этого:

playlistSchema.virtuals('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
  })
...