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

标签 node.js sql-server sequelize.js

我有一个表 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/

相关文章:

node.js - 使用 sequelize POST 方法在 nodejs 中插入新记录

c# - SQL Server 连接数有限制吗?

SQL 日期逻辑子句

node.js - 模型和迁移之间的重复数据

node.js - 在 Sequelize 中预保存钩子(Hook)和实例方法?

node.js - Postgres 和 Sequelize - 无法读取未定义的属性 'name'

javascript - 避免 Node 中的回调 hell

javascript - Nodejs中的数组内存分配

sql-server - 乌类图 : Silent install of mssql-tools and unixodbc-dev (automatically accept EULA)

javascript - 从 Sequelize getter 方法访问关联表