Mongodb和Express

Mongodb和Express,mongodb,express,Mongodb,Express,我试图在MongoDB中实现相关的数据概念。我有一个收集用户和一个收集帖子。现在posts集合已经创建了_,通过它引用users集合。但是,我无法检索相关数据。下面是我的一些模式 { "posts" { created_by:{ type:mongoose.Schema.ObjectId, ref:'User'}, created_at:{ type:Date,default:Date.now }, te

我试图在MongoDB中实现相关的数据概念。我有一个收集用户和一个收集帖子。现在posts集合已经创建了_,通过它引用users集合。但是,我无法检索相关数据。下面是我的一些模式

{   "posts"
        {
            created_by:{ type:mongoose.Schema.ObjectId, ref:'User'},
            created_at:{ type:Date,default:Date.now },
            text:String
        }
}
{
       "users"
         {
             username:String,
             password:String,
             created_at:{type:Date,default:Date.now}
       }
}
用一个很好的例子来阐述。我在这里为你摘录了要点

{
var personSchema = Schema({
  _id     : Number,
  name    : String,
  age     : Number,
  stories : [{ type: Schema.Types.ObjectId, ref: 'Story' }]
});

var storySchema = Schema({
  _creator : { type: Number, ref: 'Person' },
  title    : String,
  fans     : [{ type: Number, ref: 'Person' }]
});

var Story  = mongoose.model('Story', storySchema);
var Person = mongoose.model('Person', personSchema);

}
现在有了两个模型story和person,其中story通过_creator字段引用person

现在,要在通过故事查询时填充_creator,请执行以下操作:

{

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"
});
}
但您还需要确保已正确保存记录,以便正确检索。保存时,只需分配_id即可。请参见下文

{
var aaron = new Person({ _id: 0, name: 'Aaron', age: 100 });

aaron.save(function (err) {
  if (err) return handleError(err);

  var story1 = new Story({
    title: "Once upon a timex.",
    _creator: aaron._id    // assign the _id from the person
  });

  story1.save(function (err) {
    if (err) return handleError(err);
    // thats it!
  });
});

}

您好,用户3894192,欢迎来到堆栈溢出。你能不能更详细地描述一下你所说的无法检索相关数据是什么意思?如果您能向我们展示数据库中数据的一些示例,以及您想要查询的组合数据的示例,这将有所帮助。此外,您确实需要显示到目前为止您尝试过的内容,并描述哪些内容不起作用(例如,通过打印查询输出)。使用
mongoose
?很好。很高兴我能帮忙。你能接受我的回答吗。