1. ホーム
  2. javascript

[解決済み] Mongoose で別のスキーマを参照する

2022-07-03 12:39:54

質問

のような2つのスキーマがある場合、どのようにすればよいのでしょうか?

var userSchema = new Schema({
    twittername: String,
    twitterID: Number,
    displayName: String,
    profilePic: String,
});

var  User = mongoose.model('User') 

var postSchema = new Schema({
    name: String,
    postedBy: User,  //User Model Type
    dateCreated: Date,
    comments: [{body:"string", by: mongoose.Schema.Types.ObjectId}],
});

上の例のようにつなげようとしたのですが、どうすればいいのかわかりませんでした。最終的には、このようなことができれば、私の人生はとても楽になるのですが......。

var profilePic = Post.postedBy.profilePic

どのように解決するのですか?

populate メソッドがお探しのもののようです。まず、投稿スキーマを少し変更します。

var postSchema = new Schema({
    name: String,
    postedBy: {type: mongoose.Schema.Types.ObjectId, ref: 'User'},
    dateCreated: Date,
    comments: [{body:"string", by: mongoose.Schema.Types.ObjectId}],
});

次にモデルを作成します。

var Post = mongoose.model('Post', postSchema);

そして、クエリを作成するときに、このようにリファレンスを入力します。

Post.findOne({_id: 123})
.populate('postedBy')
.exec(function(err, post) {
    // do stuff with post
});