[英]How to populate multiple collections in mongoose nodejs and ejs
背景:所以我正在尝试使用 ejs nodejs express 和 mongoose 制作一个产品管理系统,用户可以将产品发布给特定员工,然后也可以退回。 我遇到的问题是,在退回产品后,我无法同时在 ejs 文件中填充产品和员工集合。 我已经尝试了很多搜索,但无法找到解决方案。
const issue_return_details = (req, res) => {
var perPage = 3;
var page = req.params.page || 1;
IssueBack.find()
.skip((perPage * page) - perPage)
.limit(perPage)
.populate([{ path: "issue",
populate: { path: "product", // works
populate : { path: "category", // works
populate : { path: "employee"}}}}]) // doesnt work
.then((issueback) => {
IssueBack.count().then((count) => {
res.render("products/issue/returnDetails", {
user: req.user,
issueback: issueback,
current : page,
pages : Math.ceil(count / perPage),
message: req.flash("success_msg"),
});
})
})
.catch((err) => {
console.log(err);
});
};
现在,如果我与员工切换产品,那么我可以呈现所有员工信息,但产品和类别停止工作。
const issue_return_details = (req, res) => {
var perPage = 3;
var page = req.params.page || 1;
IssueBack.find()
.skip((perPage * page) - perPage)
.limit(perPage)
.populate([{ path: "issue",
populate: { path: "employee",
populate : { path: "category",
populate : { path: "product"}}}}])
.then((issueback) => {
IssueBack.count().then((count) => {
res.render("products/issue/returnDetails", {
user: req.user,
issueback: issueback,
current : page,
pages : Math.ceil(count / perPage),
message: req.flash("success_msg"),
});
})
})
.catch((err) => {
console.log(err);
});
};
<% if (issueback.length> 0) { %> <% issueback.forEach(issueback=> { %>
<tr>
<td><%= issueback.issue.employee.ename %></td>
<td><%= issueback.issue.employee.email %></td>
<td><%= issueback.issue.employee.enumber %></td>
<td><%= issueback.issue.employee.cnumber %></td>
<td><%= issueback.issue.product.prodid %></td>
<td><%=issueback.issue.product.title %></td>
<td><%=issueback.issue.product.manufacturer %></td>
<td><%=issueback.issue.product.category.title %></td>
<% var date = issueback.returnTime %> <% var formated =
date.toLocaleString(date); %>
<td><%= formated %></td>
<td><%= issueback.qty %></td>
const mongoose = require('mongoose');
const Schema = mongoose.Schema;
const issueBackSchema = new Schema({
remarks: {
type: String,
required: true
},
qty: {
type: Number,
default: 0
},
issue: {
type: mongoose.Schema.Types.ObjectId,
ref: 'issue'
},
returnTime: {
type: Date,
default: Date.now()
}
});
const IssueBack = mongoose.model('issueBack',issueBackSchema);
module.exports = IssueBack;
const mongoose = require('mongoose');
const Schema = mongoose.Schema;
const issueSchema = new Schema({
employee: {
type: mongoose.Schema.Types.ObjectId,
ref: 'employee'
},
status: {
type: Boolean,
default: false
},
description: {
type: String,
required: true
},
qty: {
type: Number,
default: 0
},
product: {
type: mongoose.Schema.Types.ObjectId,
ref: 'Prodcut'
},
issueTime: {
type: Date,
default: Date.now()
}
});
const Issue = mongoose.model('issue',issueSchema);
module.exports = Issue;
const mongoose = require('mongoose');
const Schema = mongoose.Schema;
const productSchema = new Schema({
prodid: {
type: String,
required: true
},
title: {
type: String,
required: true
},
manufacturer: {
type: String,
required: true
},
qty:{
type: Number,
default: 0
},
category: {
type: mongoose.Schema.Types.ObjectId,
ref: 'category'
},
prange:{
type: String
},
pdate:{
type: Date
},
wdate:{
type: Date
},
desc: {
type: String
},
user:{
type: mongoose.Schema.Types.ObjectId,
ref: 'User'
},
coverImage: {
type: Buffer,
required: true
},
coverImageType: {
type: String,
required: true
}
}, { timestamps: true });
productSchema.virtual('coverImagePath').get(function() {
if (this.coverImage != null && this.coverImageType != null) {
return `data:${this.coverImageType};charset=utf-8;base64,${this.coverImage.toString('base64')}`
}
});
const Prodcut = mongoose.model('Prodcut',productSchema);
module.exports = Prodcut;
提前致谢。
尝试这个。 你必须嵌套你的填充 object。
const issue_return_details = (req, res) => {
var perPage = 3;
var page = req.params.page || 1;
IssueBack.find()
.skip((perPage * page) - perPage)
.limit(perPage)
.populate([
{
"path": "issue",
"populate": [
{
"path": "employee"
},
{
"path": "product",
"populate": { "path": "category" }
}
]
}
]).then((issueback) => {
IssueBack.count().then((count) => {
res.render("products/issue/returnDetails", {
user: req.user,
issueback: issueback,
current : page,
pages : Math.ceil(count / perPage),
message: req.flash("success_msg"),
});
})
})
.catch((err) => {
console.log(err);
});
};
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.