我意识到这可能有一个简单的答案,但我无法想出任何东西,搜索现在几个小时都没有发现任何东西。基本上,情况是我有两个表的查询(超过这个,但为此目的只有两个)。我试图在一个条件下加入左外连接,在另一个条件下加一个完全外连接。有没有人对我如何做到这一点有任何想法?
Select ResourceID, Month, Cost, Available
FROM TableA
JOIN TableB
ON TableA.ResourceID=TableB.ResourceID --I want only resources in Table A
AND TableA.Month=TableB.Month --all months in TableA or TableB
--but still create a single line for that resource/month
以下是每个表的数据样本和预期结果
表A
ResourceID Month Cost
1 Jan 30
1 Mar 90
1 Jun 100
1 Aug 120
1 Sep 60
2 Feb 80
2 Apr 90
2 May 60
2 Jul 70
4 Jan 50
4 Feb 60
表B
ResourceID Month Available
1 Jan 120
1 Feb 160
1 Mar 140
1 Apr 150
1 May 130
2 Jan 150
2 Feb 100
2 Mar 150
2 Apr 120
2 May 125
3 Jan 170
3 Feb 140
3 Mar 180
结果
ResourceID Month Cost Available
1 Jan 30 120
1 Feb 160
1 Mar 90 140
1 Apr 150
1 May 130
1 Jun 100
1 Jul 120
1 Aug 120
1 Sep 60
2 Jan 150
2 Feb 80 100
2 Mar 150
2 Apr 90 120
2 May 60 125
2 Jul 70
4 Jan 50
4 Feb 60
非常感谢任何帮助!
答案 0 :(得分:1)
如果你想要表A中的资源和两个表中的月份,那么我会使用union
更多地接受这一点:
select ResourceId, Month, sum(Cost) as cost, sum(Available) as available
from ((select ResourceId, Month, Cost, NULL as Available
from tableA
) union all
(select ResourceId, Month, NULL as Cost, Available
from tableB
where exists (select 1 from tableA where tableA.resourceId = tableB.resourceId)
)
) ab
group by ResourceId, Month
order by ResourceId, Month;
答案 1 :(得分:1)
您可以将结果构建为外部联接,然后过滤掉来自B的记录而不使用相应的A条目
Select Coalesce(TableA.ResourceID, TableB.ResourceID) as ResourceID
, Coalesce(TableA.Month,TableB.Month) as Month, Cost, Available
FROM TableA OUTER JOIN TableB
ON TableA.ResourceID=TableB.ResourceID --I want only resources in Table A
AND TableA.Month=TableB.Month --all months in TableA or TableB
--but still create a single line for that resource/month
WHERE TableB.ResourceID IS NULL OR TableB.ResourceID IN (SELECT DISTINCT ResourceID FROM TableA)
因为如果它来自表A而没有表B中的匹配,那么TableB.ResourceID将为NULL并且你将保留它。
如果它来自两者(匹配RedID和Month),那么TableB.ResourceID将在A中,WHERE子句的后半部分将保持不变。
如果它来自B但在A中具有匹配的ResID,则WHERE子句的后半部分也将保留它,即使它在A中没有对应的(ID,Month)对。
你需要COALESCE,因为如果WHERE子句的后半部分保留了一个来自B但没有匹配ID的记录,A中的月份,则A.ID和A.Month将为NULL。