gpt4 book ai didi

sequelize.js - Sequelize : association is referencing to wrong foreignKey column name

转载 作者:行者123 更新时间:2023-12-03 22:16:30 31 4
gpt4 key购买 nike

我在这个问题上苦苦挣扎了几个小时,我似乎找不到解决这个令人困惑的错误的方法。我正在尝试使用连接表进行查询并使用嵌套对象显示结果。

所以表是这样的:blogs 表通过 blogs 上的外键 accounts_id 关联到 accounts 表> 表,这似乎是一个简单的连接查询,但我不能让 sequelize 使用正确的外键列名,因为它认为外键被称为 account_id

模型是这样定义的:

账户:

module.exports = function(sequelize, DataTypes) {
return sequelize.define('accounts', {
id: {
type: DataTypes.INTEGER(11),
allowNull: false,
primaryKey: true,
autoIncrement: true
},
username: {
type: DataTypes.STRING,
allowNull: false
},
............
}, {
tableName: 'accounts',
timestamps: false,
freezeTableName: true
});

博客:

module.exports = function(sequelize, DataTypes){
var model = sequelize.define("blogs", {
id: {
type: DataTypes.INTEGER(11),
allowNull: false,
primaryKey: true,
autoIncrement: true
},
title: {
type: DataTypes.STRING,
allowNull: false,
},
content: {
type: DataTypes.STRING,
allowNull: false
},
accounts_id: {
type: DataTypes.INTEGER,
allowNull: false,
},
............
}, {
tableName: "blogs",
timestamps: false,
underscored: true
});

model.belongsTo(sequelize.models.accounts);
sequelize.models.accounts.hasMany(model, {targetKey: "accounts_id"});

return model;
};

查询是这样的:

var criteria = {
include: [$db.models.accounts]
};

return model.findAll(criteria);

但它会抛出 Error: ER_BAD_FIELD_ERROR: Unknown column 'blogs.account_id' in 'field list'

最佳答案

有很多不支持目标键选项 https://github.com/sequelize/sequelize/issues/4258

你能试试吗,在两者中都点外键

    model.belongsTo(sequelize.models.accounts, {foreignKey: "accounts_id"});
sequelize.models.accounts.hasMany(model, {foreignKey: "accounts_id"});

关于sequelize.js - Sequelize : association is referencing to wrong foreignKey column name,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43025861/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com