gpt4 book ai didi

javascript - Sequelize 中的关联未按预期工作

转载 作者:行者123 更新时间:2023-11-29 13:40:11 25 4
gpt4 key购买 nike

我试图在 Sequelize 中关联两个表,但我收到 SequelizeEagerLoadingError,尽管尝试了此平台上的所有可用修复,但一个表未与另一个表关联。

我有两个表,用户和项目。

用户(user.js)

const User = dbconnection.sequelize.define('users', {
id: { type: Sequelize.INTEGER, autoIncrement: true, primaryKey: true},
name: {
type: Sequelize.STRING(80),
allowNull: false
},
email: {
type: Sequelize.STRING(120),
allowNull: false,
unique: true
},
dob: {
type: Sequelize.DATEONLY,
allowNull: false
},
password: {
type: Sequelize.STRING(256),
allowNull: false
}

});

User.associate = models => {
User.hasMany(models.Item, { as: 'items',foreignKey: 'user_id' })
}

dbconnection.sequelize.sync({ force: false })
.then(() => {
//console.log('Table created!')
});

module.exports = {
User
};

项目(item.js)

const Item = dbconnection.sequelize.define('items', {
id: { type: Sequelize.INTEGER, unique: true, autoIncrement: true, primaryKey: true},
item: {
type: Sequelize.STRING(80),
allowNull: true
},
item_type: {
type: Sequelize.STRING(10),
allowNull: false
},
comment: {
type: Sequelize.STRING(1000),
allowNull: true
},
user_id: {
type: Sequelize.INTEGER,
allowNull: false,
references: { model: 'users', key: 'id' }
},
});

Item.associate = models => {
Item.belongsTo(models.User, { as: 'users',foreignKey: 'user_id' })
}

dbconnection.sequelize.sync({ force: false })
.then(() => {
// console.log('Table created!')
})
});

module.exports = {
Item
};

User hasMany(Item) 而 Item belongsTo(User) 如上所示。

但是,当我查询 Item 表时(如下所示),

const usersdb = require('./userdb')
const itemsdb = require('./itemdb')

class ItemsController {
static async getAllItems(req, res, next) {
try{
let allitems = await itemsdb.Item.findAll({
include: [{
model: usersdb.User
}]
})
return {items: allitems, status: true}
}
catch (e) {
return {items: e, status: false}
}
}
}

module.exports = ItemsController;

我收到“用户未关联到项目!”的 SequelizeEagerLoadingError!

我已经尝试了所有可用的修复程序,包括 thisthis等等,但没有成功。

最佳答案

我终于找到了解决方法。首先,我删除了表格并丢弃了模型定义。其次,我使用 sequelize model:create --name ModelName --attributes columnName:columnType 命令生成了迁移和模型。然后,我使用生成的模型将两个表关联起来,就像我之前所做的那样。最后,我运行了 sequelize db:migrate 命令来创建表并在运行查询时成功了!

之前,我是手动创建模型。我还在加载模型后使用 sequelize.sync({force: false/true}) 命令创建了表。

用户模型(user.js)

'use strict';
module.exports = (sequelize, DataTypes) => {
const User = sequelize.define('User', {
email: {
type: DataTypes(120),
allowNull: false,
unique: true
},
dob: {
type: DataTypes.DATEONLY,
allowNull: false
},
password: {
type: DataTypes.STRING(256),
allowNull: false
}
}, {});
User.associate = function(models) {
User.hasMany(models.Item, {as: 'Item', foreignKey: 'user_id'})
};
return User;
};

项目模型(item.js)

'use strict';
module.exports = (sequelize, DataTypes) => {
const Item = sequelize.define('Item', {
item: {
type: DataTypes.STRING(80),
allowNull: true
},
item_type: {
type: DataTypes.STRING(10),
allowNull: false
},
comment: {
type: DataTypes.STRING(1000),
allowNull: true
},
user_id: {
type: DataTypes.INTEGER,
allowNull: false,
references: { model: 'User', key: 'id' }
}
}, {});
Item.associate = function(models) {
Item.belongsTo(models.User, { as: 'User',foreignKey: 'user_id' })
};
return Item;
};

查询(queryitem.js)

const Item = require('../models').Item
const User = require('../models').User

class ItemsController {
static async getAllItems() {
try{
let allitems = await Item.findAll({
include: [{
model: User,
as: 'User'
}]
})
return {items: allitems, status: true}
}
catch (e) {
return {items: e, status: false}
}
}
}

module.exports = ItemsController;

关于javascript - Sequelize 中的关联未按预期工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56725239/

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