У меня есть одна таблица Project с внешним ключом product_id из таблицы Product,
Project table:
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, я ожидаю получить role1, role3 и role5 через его product_id, 1.
Есть ли в Sequlize возможность делать запросы в одном статусе? В настоящее время я получаю сначала product_id проекта, а затем нахожу все роли с этим product_id, который представляет собой два статуса. Я использую Sql Сервер.
Вот что я пробовал:
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" })