繁体   English   中英

如何在 mongoose nodejs 和 ejs 中填充多个 collections

[英]How to populate multiple collections in mongoose nodejs and ejs

背景:所以我正在尝试使用 ejs nodejs express 和 mongoose 制作一个产品管理系统,用户可以将产品发布给特定员工,然后也可以退回。 我遇到的问题是,在退回产品后,我无法同时在 ejs 文件中填充产品和员工集合。 我已经尝试了很多搜索,但无法找到解决方案。

这是返回 controller 的代码

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);
    });
};

在此处输入图像描述

相关 Ejs 代码

        <% 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>

返回 Model(MongoDB 中的回溯)

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;

问题 Model

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;

产品 model

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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM