gpt4 book ai didi

sql - LEFT OUTER JOIN 未显示 JOIN 右侧缺少的行

转载 作者:行者123 更新时间:2023-12-04 05:50:04 25 4
gpt4 key购买 nike

我正在建立一个查询以返回给定员工,该人角色所需的所有“测试”,其中该人未参加测试,或测试已过期。

第一部分列出了员工角色的所有测试,如下所示:

SELECT e.EMP_NO, e.POS_CODE, p.PROPERTY_CODE, p.PROPERTY_VALUE
FROM COMPANY_PERS_ASSIGN e
INNER JOIN COMPANY_POS_PROPERTY_ALL p ON p.POS_CODE = e.POS_CODE
WHERE e.EMP_NO = '3615';

到目前为止一切顺利……对于本示例,它列出了此人员角色所需的 4 个测试。

接下来,我需要将其加入显示员工已参加哪些测试的 View :
SELECT e.EMP_NO, e.POS_CODE, p.PROPERTY_CODE, p.PROPERTY_VALUE, ep.PROPERTY_CODE, ep.PROPERTY_VALUE
FROM COMPANY_PERS_ASSIGN e
INNER JOIN COMPANY_POS_PROPERTY_ALL p ON p.POS_CODE = e.POS_CODE
LEFT OUTER JOIN COMPANY_EMPLOYEE_PROPERTY_ALL ep ON ep.PROPERTY_VALUE = p.PROPERTY_VALUE
WHERE e.EMP_NO = '3615';

使用 LEFT OUTER JOIN,我希望它返回上一个查询中的所有行,以及我们刚刚添加的 View 中的任何匹配信息。

如果这个角色的测试是 A/B/C/D,并且如果这个员工做了一次 A 测试,D 测试了 3 次,我会期望以下输出:
3615 POS1 A A A A
3615 POS1 B B
3615 POS1 C C
3615 POS1 D D D D
3615 POS1 D D D D
3615 POS1 D D D D

但相反,我得到:
3615 POS1 A A A A
3615 POS1 D D D D
3615 POS1 D D D D
3615 POS1 D D D D

我对 T-SQL 比 PL/SQL 更熟悉,但据我所知,我应该采取正确的方法,但显然有些地方不对。

我错过了什么?

更新:
我意识到我的逻辑错误 - 在我的原始代码示例中,我加入了 COMPANY_EMPLOYEE_PROPERTY_ALL 表,通过 PROPERTY_VALUE(即测试)链接,但没有考虑到员工。

为了解决这个问题(并尝试不同的方法),我引入了一个子查询:
SELECT e.EMP_NO, e.POS_CODE, p.PROPERTY_VALUE, p.value_description, ep.PROPERTY_VALUE, ep.value_description, ep.VALID_TO
FROM COMPANY_PERS_ASSIGN e
INNER JOIN COMPANY_POS_PROPERTY_ALL p ON p.POS_CODE = e.POS_CODE
LEFT OUTER JOIN
(Select ep.PROPERTY_VALUE, ep.VALID_TO, ep.value_description
FROM COMPANY_PERS_ASSIGN e
INNER JOIN COMPANY_EMPLOYEE_PROPERTY_ALL ep ON ep.EMP_NO = e.EMP_NO
WHERE e.EMP_NO = '3615') ep on ep.PROPERTY_VALUE = p.PROPERTY_VALUE
WHERE e.EMP_NO = '3615'
AND (to_char(ep.VALID_TO) <= '17-APR-12' OR ep.VALID_To IS NULL);

此解决方案有效。

但是,鉴于我发现的问题,我该如何重新调整原始方法?或者我应该坚持使用这个解决方案。我正处于“工作”阶段,但我一直在寻找进一步的优雅(和学习的机会)。

最佳答案

尝试将与 EMP_NO 相关的条件添加到您的左外连接条件中。 :

SELECT e.EMP_NO, e.POS_CODE, p.PROPERTY_CODE, p.PROPERTY_VALUE, ep.PROPERTY_CODE, ep.PROPERTY_VALUE
FROM COMPANY_PERS_ASSIGN e
INNER JOIN COMPANY_POS_PROPERTY_ALL p ON p.POS_CODE = e.POS_CODE
LEFT OUTER JOIN COMPANY_EMPLOYEE_PROPERTY_ALL ep ON ep.PROPERTY_VALUE = p.PROPERTY_VALUE
AND ep.EMP_NO = e.EMP_NO
WHERE e.EMP_NO = '3615'
-- AND (ep.VALID_TO <= to_date('20120417', 'yyyymmdd') OR ep.VALID_To IS NULL)

关于sql - LEFT OUTER JOIN 未显示 JOIN 右侧缺少的行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10189820/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com