sql - 如果 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 |
解决方案
添加 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');
推荐阅读
- javascript - 正则表达式 - 输出字符无效
- amp-html - 是否可以自定义 AMP Stories 的分享按钮位置?
- javascript - 在另一个函数中使用异步等待中的返回值
- php - 替换扩展实体类型的“label.form.empty_value”
- java - 从短/字节缩小隐式转换
- excel - 如何根据与另一列的完全匹配对列进行排序
- flask - 带有 websockets 和 flask-socketio 的 Python 到 Python WebSockets
- java - 如果条件可以为真或假,为什么有必要
- jquery-selectors - Cheerio:选择多个输入的值
- mysql - 如何在mysql中实现join