簡體   English   中英

使用mongodb嵌入集合

[英]Embed the collections using mongodb

我只是開始使用mongodb和nodejs。 我知道mongodb不支持joins.I只是將數據插入mongodb中,我的文檔看起來像:

{
   "_id": ObjectId("564dacf84d52785c1d8b4567"),
    "content": "This blog created by karanSofat",
   "html": "<p>This blog created by karanSofat</p>\n",
} 

現在,用戶對此帖子發表評論。 應該是這樣的:

{
   "_id": ObjectId("564dacf84d52785c1d8b4567"),
   "comments": [
     {
       "name": "sumit",
       "email": "sumit@ggi.net",
       "comment": "this is also well for me",
       "posted_at": ISODate("2015-11-19T11:06:27.172Z") 
    } 
  ],
   "content"▼: "This blog created by karanSofat",
   "html": "<p>This blog created by karanSofat</p>\n", 
}

這是我的模特,

   //post model
// grab the mongoose module
var mongoose = require('mongoose');

// define our nerd model
// module.exports allows us to pass this to other files when it is called
module.exports = mongoose.model('post', {
    content : {type : String, default: ''},
    html : {type : String, default: ''}


});
//comment model
 var mongoose = require('mongoos
      module.exports = mongoose.model('comment', {
        name : {type : String, default: ''},
        email : {type : String, default: ''},
        comment : {type : String, default: ''},
        posted_at : {type : date, default: ''}

    });

我的問題是我不知道我使用哪種方式使用nodejs插入評論數據,並且我的文檔將被嵌入。 這是我的代碼:

app.post('/comments/:id', function(req, res) {
var Comment = require("../app/models/comments");//comment Model
var blog = require("../app/models/blog");//blog model

var id = req.params.id; //postId
var comments = JSON.parse(JSON.stringify(req.body)); //commentdata

//code Should be here

res.json({data:id,data2:input});
});

請幫忙

卡蘭,

假設您具有以下架構:

var Comments = new Schema({
    name: String,
    email: String,
    comment: String,
  , posted_at: Date
});

var BlogPost = new Schema({
  content     : String,
  html      : String,
  comments  : [Comments],
});

mongoose.model('BlogPost', BlogPost);

您可以將嵌入文檔添加到數組中,如下所示:

// retrieve my model
var BlogPost = mongoose.model('BlogPost');

// create a blog post
var post = new BlogPost();

// create a comment
post.comments.push({
   "name": "sumit",
   "email": "sumit@ggi.net",
   "comment": "this is also well for me",
   "posted_at": ISODate("2015-11-19T11:06:27.172Z") 
});

post.save(function (err) {
  if (!err) console.log('Success!');
});

暫無
暫無

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

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