我正在使用sequelize
作为我的nodejs
网络应用程序ORM
我有2个模型,Offer
和Game
。它们之间存在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个动作中创建Offer
和Game
?
编辑:
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;
};
答案 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'
});