我有一个表项目,其产品表中有外键product_id,
项目表:
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" })
答案 0 :(得分:0)
const project = await Project.findAll({
include: [
{
model: Role,
as: "products",
},
],
});
// you access all role of Project using
let roles = project[0].Role;