Sequlize объединяет две таблицы с одинаковым внешним ключом - PullRequest
0 голосов
/ 06 августа 2020

У меня есть одна таблица 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" })

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...