zoukankan      html  css  js  c++  java
  • [转] mongoose的populate

    MongoDB是文档型数据库,所以它没有关系型数据库joins 特性。但是mongoose也有自己的方法来解决两个表之间的关联问题,Mongoose就是通过populate来解决这个问题的。接下来分享一下populate的方法。

    populate的用法一

    • 创建两个model

    var personSchema = Schema({
      _id     : Number,
       name    : String,
       age     : Number,
       });
     var storySchema = Schema({
       _creator : { type: Number, ref: 'Person' },
       title    : String,
       
    });
    var Story  = mongoose.model('Story', storySchema);
    var Person = mongoose.model('Person', personSchema);
    • 创建数据

     var aaron = new Person({ _id: 0, name: 'Aaron', age: 100 });
     aaron.save(function (err) {
       if (err) return ;
      
       var story1 = new Story({
         title: "Once upon a timex.",
         _creator: aaron._id   
       });
      
       story1.save(function (err) {
         if (err) return ;
    
    
       });
    //   });
    • populate的使用

     Story
     .findOne({ title: 'Once upon a timex.' })
     .populate('_creator')
     .exec(function (err, story) {
       if (err) return handleError(err);
       console.log('The creator is %s', story._creator.name);
       // prints "The creator is Aaron"
    }
    
     })
     
       

    populate的用法二

    var articlesSchema = new mongoose.Schema({
        title : {type:String,default:""},
        content : {type:String,default:''},
        reduce_content:{type:String},
        time : {type:Date,default:Date.now},
         like_count:{type:Number,default:0},
        comments:
        [{
        reply:{type:mongoose.Schema.Types.ObjectId,ref:'user'},
        time:{type:Date,default:Date.now},
        content:{type:String},
        replyTo:{type:String,default:''},
        like_count:{type:Number,default:0},
      }],
        type:{type:String,default:""},
        isPublish:{type:Boolean,default:true},
        
    });
    
    var  articles=mongoose.model("articles",articlesSchema
    
    );

    这里的数据库设计是article下嵌套了数组comments 而commets下的reply和user表建立了连接。
    如何使用populate呢?

     
    db.articles.findOne({_id:id}).populate('comments.reply')即可

  • 相关阅读:
    数据类型
    python安装
    计算机基础
    Ajax--1
    ASP.net+MVC--2
    More lumber is required
    History Grading
    strcmp() Anyone?
    How Many Points of Intersection?
    Remember the Word
  • 原文地址:https://www.cnblogs.com/chris-oil/p/12639587.html
Copyright © 2011-2022 走看看