Как мне объединить две схемы в пн goose? - PullRequest
0 голосов
/ 20 февраля 2020

У меня есть MongoDB со следующими двумя schmemas:

Survey:
{
    "_id": {
        "$oid": "5e4ed11c73c4c900ef824b8a"
    },
    "isRunning": false,
    "title": "TestSurvey",
    "dateOfCreation": {
        "$date": {
            "$numberLong": "1582223644144"
        }
    },
    "dateOfExpiration": {
        "$date": {
            "$numberLong": "1592438400000"
        }
    },
    "isPublic": true,
    "user": {
        "$oid": "5e1f3c9868141f0055208da9"
    },
    "maxParticipants": {
        "$numberInt": "50"
    },
    "questions": [],
    "__v": {
        "$numberInt": "0"
    }
}
User:
{
    "_id": {
        "$oid": "5e1f3c9868141f0055208da9"
    },
    "firstName": "Bob",
    "lastName": "Mueller",
    "userName": "bob",
    "email": "bob@bob.com",
    "salt": "4604426e4ac451654f28025ffe9d09e0",
    "hash": "957eadeef377f9c88082589152b808d6d9611cb5df97db9f15536d9bf47ffd5cad32de916c7cee3dc514a383e7135b645aba7ff75a2365cf2d3ceb2b48415f86679c5ea6bba99a805dcbf9da0c324173d3e2c8d7690120a45122af872c77abf95748df6fa0546db56d88fa0f9055caf6fe78dc4605e774187cc8fa659878402f74ab63765477d6e4590585c018bcbdacd8f363c9b7ce82e2b60700b8f90eaf25b926d4623d1ad9dcb9af2227600ed52175b42cbd4794b6c4aecac11415efc03d2691ae895397117e985172bb0c72242a6ea0d81f26fa936623b97c57c7bfb10bcc2cb2ba39baa2430e584c39f07e34c8e550deae4bf7877bf17d9707392d427e",
    "createdAt": {
        "$date": {
            "$numberLong": "1579105433056"
        }
    },
    "updatedAt": {
        "$date": {
            "$numberLong": "1582223618030"
        }
    },
    "__v": {
        "$numberInt": "0"
    }
}

Моя цель - составить список, в котором я могу видеть все опросы, которые публикуются c (isPubli c : true), userName пользователя, создавшего опрос, и срок действия опроса. Чтобы это работало, мне нужно сослаться на пользователя, используя userId в схеме опроса.

В моем проекте у меня есть следующий контроллер:

const {Survey} = require('../../models');
const {User} = require('../../models');
const mongoose = require('mongoose');
const Schema = mongoose.Schema;

class HomeController {

  async homeView(req, res, next) {
    try {
      const survey = await Survey.findOne();
      const user = await User.findOne();

      const userSchema = new Schema({
        name: String,
        _id: Schema.ObjectId,
      })

      const surveySchema = new Schema({
        title: String,
        expirationDate: Date,
        creator: [userSchema]
      })

      const surveys = mongoose.model('surveys', surveySchema);

      res.render('home/homeView', {
        title: 'All surveys',
        surveys,
    });
    } catch (err) {
      next(err);
    }

  }
}

module.exports = new HomeController();

Как видите, я У меня есть отдельные модели для пользователя и опроса, но я пока выясняю, как их объединить. Я пытался использовать страницу справки Mon goose, но это не помогло.

Я надеюсь, что кто-то может мне помочь, так как я все еще новичок в этом топи c.

1 Ответ

0 голосов
/ 20 февраля 2020

Это возможно с помощью subdocuments. Субдокументы позволяют вам объявлять отдельные модели / схемы и затем связывать их / вызывать их внутри других схем.

Вот небольшой текст из документации: https://mongoosejs.com/docs/subdocs.html

Субдокументы - это документы, встроенные в другие документы. В Mon goose это означает, что вы можете вкладывать схемы в другие схемы. Понедельник goose имеет два различных понятия вложенных документов: массивы вложенных документов и отдельные вложенные вложенные документы.

var childSchema = new Schema({ name: 'string' });

var parentSchema = new Schema({
  // Array of subdocuments
  children: [childSchema],
  // Single nested subdocuments. Caveat: single nested subdocs only work
  // in mongoose >= 4.2.0
  child: childSchema
});
...