15

私は Sequelize を初めて使用し、1 対多の関係をどのようにモデル化すればよいかを理解しようとしています。

私の問題は次のとおりです。1学期、多くの論文。

var Term = sequelize.define( 'Term', ... );
var Paper = sequelize.define( 'Paper', ... );

用語があるとしましょう。各学期には多くの論文が含まれる可能性があり、自分の学期の論文を追加/削除したいと考えています。また、学期のすべての論文を入手したいと思います。

var term;
...
term.getPapers( ... );
term.setPapers( ... );
term.addPaper( paper );
term.removePaper( paper );

今、私が紙を持っているとしましょう。論文のタームを取得/設定したいです。

var paper;

...

paper.getTerm();
paper.setTerm();

続編を使用してどのように達成できますか? 私は何時間もドキュメントを勉強しており、ネットでいくつかの接着剤を探していますが、結果はありません. この種の関連付けは、sequelize ではほとんど文書化されていません (1 対 1 および多対多の方がはるかに優れています)。

更新

わかりました、数時間後、私はそれがどのように機能するかを理解しました:

Term.hasMany( Paper, { as: 'papers' } );
Paper.hasOne( Term );

これで、次のことができます。

term.addPaper( paper );
term.removePaper( paper );

paper.getTerm()
  .success( function( term )
  {
    ...
  });
paper.setTerm( term );

私は Django に慣れてきましたが、コードとドキュメントの両方の点で、Sequelize はそれほど成熟していないようです...

4

3 に答える 3

4

まず、関連付けを作成する必要があります。あなたはそれを正しくしました:

  Term.hasMany( Paper, { as: 'papers' } );
  Paper.hasOne( Term );

次に、この宣言を同期する必要があります。

  sequelize.sync();

そして今、データを永続化します。関連付ける前にオブジェクトを保存する必要があります。

  term.create()...
  paper1.create()...
  paper2.create()...

  term.setPapers([paper1, paper2]).success(function() {
     // saved!
  })

参照: http://docs.sequelizejs.com/en/1.7.0/docs/associations/#many-to-many-associations

于 2015-04-11T21:03:20.507 に答える