gpt4 book ai didi

node.js - Sequelize 连接具有相同外键的两个表

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

我有一个表 Project,外键 product_id 来自 Product 表,
项目表:

project_id  | project_name | product_id
1 | project1 | 1
2 | project2 | 2
3 | project3 | 1
4 | project4 | 3
另一个表 Role 也具有相同的外键 product_id 。
角色表:
role_id  | role_name | product_id
1 | role1 | 1
2 | role2 | 2
3 | role3 | 1
4 | role4 | 3
5 | role5 | 1
6 | role6 | 3
我正在尝试为具有相同 product_id 的项目查找所有角色,例如对于 project1,我希望通过 product_id 1 获得的角色是 role1、role3 和 role5。
Sequlize 有没有办法在一个语句中查询?我目前得到的是先获取一个项目的product_id,然后找到这个product_id的所有角色,这是两个语句。我正在使用 SQL Server。
这是我尝试过的:
const product = await Project.findOne({
where: {
projectId,
},
attributes: ["productId"],
})
const productId = product.productId
if (productId == null)
return res.status(400).send({ status: 2, msg: "We were unable to find a product type on this project.", code: "EPRODUCTNF" })
const role = await Role.findAll({
where: {
productId,
},
})
res.status(200).send(role)
我设置的关系是:
Product.belongsTo(Role, { targetKey: "productId", foreignKey: "productId", as: "roles" })
Product.belongsTo(Project, { targetKey: "productId", foreignKey: "productId", as: "projects" })
Project.hasMany(Product, { sourceKey: "productId", foreignKey: "productId", as: "products" })
Role.hasMany(Product, { sourceKey: "productId", foreignKey: "productId", as: "products" })

最佳答案

const project = await Project.findAll({
include: [
{
model: Role,
as: "products",
},
],
});

// you access all role of Project using
let roles = project[0].Role;

关于node.js - Sequelize 连接具有相同外键的两个表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63277737/

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