本文介绍了序列化targetKey不起作用的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我正在尝试使用Sequelize将两个模型"Note"和"Resource"关联起来。但是,targetKey未按预期工作。
备注模式:
module.exports = function(sequelize, DataTypes) {
return sequelize.define('note', {
NoteID: {
type: DataTypes.INTEGER(11),
allowNull: false,
primaryKey: true,
autoIncrement: true
},
Title: {
type: DataTypes.STRING(50),
allowNull: true
},
Note: {
type: DataTypes.STRING(500),
allowNull: false
},
CreatedBy: {
type: DataTypes.INTEGER(11),
allowNull: false,
references: {
model: 'resource',
key: 'ResourceID'
}
},
UpdatedBy: {
type: DataTypes.INTEGER(11),
allowNull: true,
references: {
model: 'resource',
key: 'ResourceID'
}
}
}, {
tableName: 'note'
});
};
资源模式:
module.exports = function(sequelize, DataTypes) {
return sequelize.define('resource', {
ResourceID: {
type: DataTypes.INTEGER(11),
allowNull: false,
primaryKey: true,
autoIncrement: true
},
FirstName: {
type: DataTypes.STRING(250),
allowNull: false
},
LastName: {
type: DataTypes.STRING(250),
allowNull: false
}
}, {
tableName: 'resource'
});
};
关联:
Resource.belongsTo(Note,{
foreignKey: 'UpdatedBy',
as: 'Resource_Updated_Note'
});
Note.hasOne(Resource,{
foreignKey: 'ResourceID',
targetKey: 'UpdatedBy',
as: 'Note_Updated_By'
});
Resource.belongsTo(Note,{
foreignKey: 'CreatedBy',
as: 'Resource_Created_Note'
});
Note.hasOne(Resource,{
foreignKey: 'ResourceID',
targetKey: 'CreatedBy',
as: 'Note_Created_By'
});
虽然我提到了targetKey While关联,但它在联接表时采用PrimaryKey。
执行。
Note.findAll({
include: [{
model: Resource,
as: 'Note_Updated_By'
}],
where: {
Status: {
[SQLOP.or]: ['Active', 'ACTIVE']
}
}
}).then(function (response) {
callback(response);
});
根据执行生成此SELECT查询。
SELECT * FROM `note` LEFT OUTER JOIN `resource` AS `Note_Updated_By` ON `note`.`NoteID` = `Note_Updated_By`.`ResourceID`;
而不是note
.NoteID
,应该是note
.UpdatedBy
推荐答案
从我使用的新版本开始"sequelize": "^5.8.12"
对hasOne
和hasMany
关系使用sourceKey
而不是targetKey
适合我。
ModelName.hasOne(ModelName1, {
as: 'SomeAlias',
foreignKey: 'foreign_key',
onDelete: 'NO ACTION',
onUpdate: 'NO ACTION',
sourceKey: 'YOUR_CUSTOM_ASSOCIATION_KEY'
});
这篇关于序列化targetKey不起作用的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!