gpt4 book ai didi

javascript - 如何使用带有 sequelize.js 的 hasOne 引用两个表

转载 作者:行者123 更新时间:2023-12-03 22:28:42 25 4
gpt4 key购买 nike

考虑到 sequelize-auto 生成的这 3 个模型:

sequelize.define('users', {
id: {
type: DataTypes.INTEGER,
allowNull: false,
primaryKey: true,
autoIncrement: true
},
first: {
type: DataTypes.STRING,
allowNull: true
},
last: {
type: DataTypes.STRING,
allowNull: true
}
}, {
tableName: 'users',
underscored: true,
timestamps: false
});

sequelize.define('groups', {
id: {
type: DataTypes.INTEGER,
allowNull: false,
primaryKey: true,
autoIncrement: true
},
parent_id: {
type: DataTypes.INTEGER,
allowNull: true,
references: {
model: 'groups',
key: 'id'
}
}
}, {
tableName: 'groups',
underscored: true,
timestamps: false
});

sequelize.define('user_groups', {
group_id: {
type: DataTypes.INTEGER,
allowNull: false,
primaryKey: true,
references: {
model: 'groups',
key: 'id'
}
},
user_id: {
type: DataTypes.INTEGER,
allowNull: false,
references: {
model: 'users',
key: 'id'
}
}
}, {
tableName: 'user_groups',
underscored: true,
timestamps: false
});

我期待生成 hasOne 语句,但我必须像这样指定它们:
user_groups.hasOne(orm.models.users, { foreignKey: "id" });
user_groups.hasOne(orm.models.groups, { foreignKey: "id" });

还要考虑表中的以下数据:
users (id, first, last):
1, John, Doe

group (id, parent_id):
1, NULL
2, NULL
3, NULL
4, NULL

user_groups (group_id, user_id):
1, 1
4, 1

做这个查询:
sequelize.findAll("user_groups", {
attributes: ["*"],
raw: true,
include: [{
model: models.users,
}]
});

我得到以下结果:
[ { group_id: 4,
user_id: 1,
'user.id': null,
'user.first': null,
'user.last': null },
{ group_id: 1,
user_id: 1,
'user.id': 1,
'user.first': 'John',
'user.last': 'Doe' } ]

这清楚地表明 sequelize 使用 group_id 作为 user_id 关系。

如何指定将 user_groups 关系链接到各自表的关系,以便能够将用户与多个组相关联?

我也很好奇模型定义中的“引用”键应该如何工作,因为文档不存在。

最佳答案

我能够使用这些关联获取引用的数据:

groups.hasMany(orm.models.user_groups);
user_groups.belongsTo(orm.models.groups, {foreignKey: "group_id", as: "group"});

users.hasMany(orm.models.user_groups);
user_groups.belongsTo(orm.models.users, {foreignKey: "user_id", as: "user"});

以及以下查询:
sequelize.findAll("user_groups", {
attributes: ["*"],
raw: true,
include: [
{ model: users, foreignKey: "user_id", as: "user", attributes: ["first", "last"] }
]
});

与预期的结果:
[ { group_id: 4,
user_id: 1,
'user.first': 'John',
'user.last': 'Doe' },
{ group_id: 1,
user_id: 1,
'user.first': 'John',
'user.last': 'Doe' } ]

关于javascript - 如何使用带有 sequelize.js 的 hasOne 引用两个表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37075666/

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