2

ライブラリに含まれている node-orm2 サンプル プロジェクトに基づいてノード エクスプレス アプリをビルドします。戻り値がめちゃくちゃに見える厄介な「バグ」がありました。

「ユーザー」には「権限」が 1 つしかありません。User.hasOne('permission', db.models.permission, {required: true, autoFetch: true}); また、「会社」には 1 人の所有者がいますが、これは逆なので、「ユーザー」には複数の「会社」があります。Company.hasOne('user', db.models.user, { required: true, reverse: 'companies', autoFetch: true});

最初のセットアップ:

function setup(db, cb) {
 require('./company')(orm, db);
 require('./user')(orm, db);
 require('./permission')(orm, db);

 return cb(null, db);
}

めちゃくちゃな結果:

{
  "id": 1,
  "username": "l.vanbuiten",
  "name": "Lex",
  "surname": "van Buiten",
  "age": "1992-05-13T22:00:00.000Z",
  "createdAt": "2015-12-21T23:25:04.000Z",
  "permission": {
    "id": 1,
    "username": "l.vanbuiten",
    "name": "Lex",
    "surname": "van Buiten",
    "age": "1992-05-13T22:00:00.000Z",
    "createdAt": "2015-12-21T23:25:04.000Z",
    "permission_id": 1
  },
  "companies": []
}

これらのセットアップ行を交換した後、私が望むようになりました:

それがどうあるべきか:

function setup(db, cb) {
 require('./permission')(orm, db);
 require('./user')(orm, db);
 require('./company')(orm, db);

 return cb(null, db);
}

望ましい結果

{
  "id": 1,
  "username": "l.vanbuiten",
  "name": "Lex",
  "surname": "van Buiten",
  "age": "1992-05-13T22:00:00.000Z",
  "createdAt": "2015-12-21T23:25:04.000Z",
  "permission": {
    "id": 1,
    "name": "permission name"
  },
  "companies": [
    {
      "id": 1,
      "name": "company name",
      "description": "company description",
      "createdAt": "2015-12-21T23:25:25.000Z"
    }
  ]
}

モデルの例:

var moment = require('moment');

module.exports = function (orm, db) {
var Company = db.define('company', {
    id:             {type: 'serial', key: true},
    name:           {type: 'text', required: true, unique: true},
    description:    {type: 'text', big: true},
    createdAt:  {type: 'date', required: true, time: true}
},
{
    cache: false,
    hooks: {
        beforeValidation: function () {
            this.createdAt = new Date();
        }
    },
    validations: {
        name: [
            orm.enforce.unique("Company already exist"),
            orm.enforce.ranges.length(1, undefined, "Company name cannot be empty"),
            orm.enforce.ranges.length(undefined, 50, "Company name is to long")
        ]
    },
    methods: {
        serialize: function () {
            return {
                id: this.id,
                name: this.name,
                description: this.description,
                createdAt: this.createdAt
            }
        }
    }
});
Company.hasOne('user', db.models.user, { required: true, reverse: 'companies', autoFetch: true});
};

こんなに順番が違うなんて。

4

1 に答える 1

1

node-orm2(免責事項:私は多くの経験を持っていません)

関連付けを設定している方法が問題を引き起こしているようです。

最初の設定では、モデルと関連付けを定義する順序は次のとおりです。

  • Companyモデルを作成する
  • Companyand Userthroughの間の関連付けを作成しますdb.models.user(これはまだ存在しません!)
  • Userモデルを作成する

代わりに、関連付けを作成する前に、すべてのモデルが定義されるまで待つ必要があると思います。

function setup(db, cb) {
  // Create models.
  var Permission = require('./permission')(orm, db);
  var User       = require('./user')(orm, db);
  var Company    = require('./company')(orm, db);

  // Create associations.
  Company.hasOne('user', User, { required: true, reverse: 'companies', autoFetch: true});
  ...

  // Return.
  return cb(null, db);
}

(これは、必要な各モデル ファイル内のエクスポートされた関数がモデルを返すことも前提としています (例:return Companyの最後company.js))。

于 2015-12-22T10:51:13.777 に答える