У меня есть 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.