首页 > 解决方案 > 如果 userId 与 table1 的employee_id 或 table2 的contributor_id 匹配,则 SQL 查询检索条目

问题描述

如果提供的 userId 与 table1 中的 employee_id 或 table2 中的contributor_id 匹配,我正在尝试从 table1 和 table2 中检索所有 kpi_id、kpi_name、employee_id、contributor_id。

样品表1:

ID kpi_name 员工ID
1 kpi1 5
2 kpi2 6
3 kpi3 9

样品表2:

ID kpi_id 贡献者ID
1 1 9
1 3 5
1 1 6

现在,如果给定的 userId 为 5,那么由于该用户是 kpi_id 1 的所有者和 kpi_id 3 的贡献者,结果应该如下所示:

我想要的输出:

kpi_id kpi_name 员工ID 贡献者ID
1 kpi1 5 5
3 kpi3 9 5

到目前为止,我已经尝试了以下查询:

const query = knex.select([
            't1.id as kpiId',
            't1.name as kpiName',
            't1.employee_id as employeeId',
            't2.contributor_id as contributorId'
        ]).from('table1 as t1')
            .leftJoin('table2 as t2', function () {
                this.on('t2.kpi_id', '=', 't1.id')
            })

           query.where({
                't1.employee_id': this._loggedInUser.id,
            }).orWhere(
                't2.contributor_id': this._loggedInUser.id,).orderBy('t1.id');

但是,如果有多个相同 kpi_id 的贡献者,这将返回重复的条目。我当前的 SQL 查询生成这个:

kpi_id kpi_name 员工ID 贡献者ID
1 kpi1 5 5
1 kpi1 5 6
3 kpi3 9 5

标签: sqlknex.js

解决方案


添加 distinct 和 groupBy 解决了我的问题:

const query = knex.select([
            't1.id as kpiId',
            't1.name as kpiName',
            't1.employee_id as employeeId',
            't2.contributor_id as contributorId'
        ]).from('table1 as t1')
            .leftJoin('table2 as t2', function () {
                this.on('t2.kpi_id', '=', 't1.id')
            }).groupBy('t1.id', 't1.name', 't1.employee_id', 't2.contributor_id')

           query.where({
                't1.employee_id': this._loggedInUser.id,
            }).orWhere(
                't2.contributor_id': this._loggedInUser.id,).orderBy('t1.id').distinctOn('t1.id');

推荐阅读