我对MongoDB和Mongoose相当新,我试图填充嵌套数组而没有任何运气。
用户有一个名为“诉讼”的道具'这是一个对象数组。该数组中的每个元素都包含一些道具,包括名为' forms'。
的数组 诉讼[i] .forms保留对诉讼表格集合中所有表格的引用。“诉讼程序”中没有任何内容可供参与。除了'表格'。 我试图填充嵌套的表格'每个程序的数组。
所以:
User: {
_id: ObjectId,
proceedings: [
{
_id: ObjectId,
forms: [
ObjectId,
ObjectId,
ObjectId
]
},
{
_id: ObjectId,
forms: [
ObjectId,
ObjectId,
ObjectId
]
}
]
}
架构:
const formSchema = new Schema({
userId: {
type: mongoose.Schema.Types.ObjectId,
ref: 'User'
},
values: { type: mongoose.Schema.Types.Mixed }
}, { timestamps: true });
const proceedingsSchema = new Schema({
initial_questions: {},
forms: [
{
type: mongoose.Schema.Types.ObjectId,
ref: 'Form'
}
]
});
const userSchema = new Schema({
email: {
type: String,
default: '',
unique: true
},
password: {
type: String,
default: ''
},
sign_up_date: {
type: Object,
default: moment(),
get: parseDate
},
proceedings: [proceedingsSchema]
}, { timestamps: true });
userSchema.set('toObject', { getters: true });
userSchema.set('toJSON', { getters: true });
export const User = mongoose.model('Users', userSchema);
export const Form = mongoose.model('Forms', formSchema);
查询:
User.findOne({ _id: id })
.populate({
path: 'proceedings',
populate: {
path: 'forms',
model: 'Form'
}
})
.exec((err, user) => {
console.log(user.proceedings[0].forms)
})
结果是一个ObjectId数组,而不是填充的表单。
非常感谢任何帮助。
Mongoose - v5.0.1
答案 0 :(得分:1)
在更多地考虑@dprogramz评论后,我决定将程序移至他们自己的收藏中。此查询现在有效:
Proceeding.find({ userId: id })
.populate({
path: 'forms',
model: 'Forms'
})
.exec((err, proceedings) => {
if (err) {
logger.error(err.message);
return res.send({ error: err.message });
}
if (!proceedings) {
return res.send({ error: 'No such proceedings' });
}
return res.send({ ok: { proceedings, proceedingId: proceedings[proceedings.length - 1]._id }});
});