簡體   English   中英

mongoose 填充返回 null 填充的數組 object

[英]mongoose populate returns null array on populated object

基本上我已經創建了一個 mongo 數據庫並創建了一個 Post model,它通過 _id 引用了用戶。 我想獲取有關帖子用戶的信息,因此當我填充所選用戶時,我在 exec() 中進行了回調 function。 但結果是一個空數組。 我除了populate.exec()幫助我獲得更多關於這樣的帖子的信息

{
  posts: [  {
    _id: 5f287dd39eb82544302b974b,
    title: 'It;s a good day pt.3',
    content: 'Sunny on the morning and little cloudy in the evening :)',
    __v: 0
  }
],
  _id: 5f287adf86b8a617300122a7,
  email: 'bob@gmail.com',
  name: 'Bob',
  __v: 2
}

然而結果只是

{
  posts: [],
  _id: 5f287adf86b8a617300122a7,
  email: 'bob@gmail.com',
  name: 'Bob',
  __v: 2
}

如果有人可以幫助我,我將不勝感激。 我的js代碼如下所示!

let mongoose = require("mongoose");
mongoose.connect("mongodb://localhost:27017/blog_demo_2", {useNewUrlParser: true, useUnifiedTopology: true});

let postSchema = new mongoose.Schema({
    title: String,
    content: String
});
let Post = mongoose.model("Post", postSchema);

let userSchema = new mongoose.Schema({
    email: String,
    name: String,
    posts: [{
        type: mongoose.Schema.Types.ObjectId,
        rel: 'Post'
    }]
});
let User = mongoose.model("User", userSchema);

User.create({
    email: "bob@gmail.com",
    name: "Bob"
});

Post.create({
    title: "It's a good day pt.3",
    content: "Sunny on the morning and little cloudy in the evening :)"
}, function (err, newlyPost) {
    if(err){
        console.log(err);
    }else{
        User.findOne({email: "bob@gmail.com"}, function (err, foundUser) {
            if(err){
                console.log(err);
            }else{
                foundUser.posts.push(newlyPost);
                foundUser.save();
            }
        })
    }
});

User.findOne({email: "bob@gmail.com"}).populate("posts").exec(function (err, user) {
    if(err){
        console.log(err);
    }else{
        console.log(user);
    }
});

你有

   posts: [{
        type: mongoose.Schema.Types.ObjectId,
        rel: 'Post'
    }]

它應該是ref作為參考,而不是rel

   posts: [{
        type: mongoose.Schema.Types.ObjectId,
        ref: 'Post'
    }]

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM