63

私は新しいプロジェクトのデータベース構造の設計に取り組んでおり、MongoDB、そして明らかに Mongoose の初心者です。

私はMongooses人口のドキュメントを読みました.1対多の関係があり、1つのPersonドキュメントと多くのStoryドキュメントがありますが、私を混乱させる部分は、ドキュメントが属してStoryいるドキュメントを参照する代わりに、スキーマがそれを設定している場所ですそのため、「所有する」ドキュメントの配列があります。PersonPersonStory

私はこれに非常に似たものを設定しています。Storyしかし、新しいドキュメントを作成するときは、Personドキュメント IDを持つ方が簡単だと考え続けています。しかし、それは、結合を使用した MySQL の関係に慣れているからかもしれません。

これが最善の方法である場合 (ドキュメントに記載されているため、そうであると確信しています)、新しいドキュメントが作成されたときに、関連するドキュメントStoryのストーリーの配列を更新する最良の方法は何ですか? People私は見ましたが、既存のドキュメントを更新して他のドキュメントへの参照を追加する(またはそれらを削除する)例は見つかりませんでした

これは私が見落とした簡単な解決策であると確信していますが、どんな助けも素晴らしいでしょう。ありがとう!

4

6 に答える 6

68

人口を参照してください。ここでは、マングースから例を抽出します。

var mongoose = require('mongoose')
, Schema = mongoose.Schema

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

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

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

というわけで、Storyモデルストア関連の例Person._idですStory._creator。のドキュメントが見つかったら、メソッドを使用して、同時に取得するモデルの属性を次のように定義Storyできます。populate()Person

Story.findOne({_id: 'xxxxxxx'}).populate('person', 'name age').exec(function(err, story) {
  console.log('Story title: ', story.title);
  console.log('Story creator', story.person.name);
});

これがあなたが探しているものだと思います。または、代わりにネストされたコレクションを使用できます。

于 2016-01-25T06:34:18.470 に答える