用相同的外键对两个表进行排序

时间:2020-08-06 06:05:21

标签: node.js sql-server sequelize.js

我有一个表项目,其产品表中有外键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" })

1 个答案:

答案 0 :(得分:0)

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

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