在sequelize中创建具有关联的模型

时间:2016-06-30 18:00:03

标签: node.js sequelize.js

我正在使用sequelize作为我的nodejs网络应用程序ORM 我有2个模型,OfferGame。它们之间存在1:1的关联,我正在考虑如何实现它 首先,我尝试使用Offer.belongsTo(Game),以便GameId驻留在Offer模型中。当我创建Offer时,我希望同时创建Game

我已将关联设置如下:

Offer.belongsTo(models.Game, {
      foreignKey: {
        allowNull: false
      }
    })

这样GameId永远不会为空。在sequelize docs中,我注意到我可以像Game一样创建Offer

models.Offer.create({Game:{"name":"The Last of Us", "platform":"PC"}},{include:[models.Game]});

但我得到了:

Unhandled rejection SequelizeDatabaseError: null value in column "GameId" violates not-null constraint

如何使用非空约束在1个动作中创建OfferGame

编辑:

module.exports = function(sequelize, DataTypes) {
  var Game = sequelize.define("Game", {
    name: {
      type: DataTypes.STRING,
      allowNull: false
    },
    platform: {
      type: DataTypes.ENUM('PC', 'PS4', 'PS3', 'XB1', 'XB360'),
      allowNull: false
    },
    cover: {
      type: DataTypes.STRING,
      allowNull: false,
      validate: {
        notEmpty: true
      }
    }
  }, {
    updatedAt: false,
    createdAt: false
  });

  return Game;
};

module.exports = function(sequelize, DataTypes) {
  var Offer = sequelize.define("Offer", {
    price: {
      type: DataTypes.INTEGER,
      validate: {
        max: 999,
        min: 0
      }
    },
    exchange: {
      type: DataTypes.BOOLEAN,
      defaultValue: true,
      allowNull: false
    }
  }, {
    updatedAt: false,
    classMethods: {
      associate: function(models) {
        Offer.belongsTo(models.Game, {
          foreignKey: {
            allowNull: false
          }
        });
      }
    }
  });

  return Offer;
};

1 个答案:

答案 0 :(得分:0)

您没有为Offer对象添加任何内容。你只是传递Game对象。

models.Offer.create({
    //set fields for 'Offer'
    Game:{"name":"The Last of Us", "platform":"PC"}
    },
    {include:[models.Game]}
);

此外,您只需在设置关联时定义foreignKey即可。约束定义存在于模型中:

Offer.belongsTo(models.Game, {
      foreignKey: 'GameId'
    });