我有这三张桌子。
Table1:
Resource1
Resource2
Resource3Table2:
Period1
Period2
Period3Table3:
Resource1 Period1
Resource1 Period2
Resource1 Period2
Resource2 Period1
Resource2 Period1
Resource3 Period3我需要得到这样的结果:
Resource1 Period1
Resource1 Period2
Resource1 Period2
Resource1 Period3
Resource2 Period1
Resource2 Period1
Resource2 Period2
Resource2 Period3
Resource3 Period3
Resource3 Period1
Resource3 Period2我尝试了外连接,但没有效果。我发现交叉连接可能会有所帮助,但我并没有成功地实现它。能有这么好的人帮我做这些事吗?
非常感谢,r。
发布于 2013-05-07 16:48:28
使用一个公用表表达式来生成所有的组合,然后使用一个外连接来包含table3中显示的重复项。
with cte as ( select resource, period
from table1 cross join table2 )
select cte.resource
, cte.period
from cte
left outer join table3
on (table3.resource = cte.resource
and table3.period = cte.period )
;这可能不会产生正确的答案,这取决于你所说的“我不知道如何摆脱不必要的行”。您呈现的输出似乎没有丢弃表中的任何行,并且您没有提供任何规则。因此,如果这不能给你想要的东西,你必须编辑你的问题来澄清问题。
发布于 2013-05-07 16:28:22
我知道你的结果,但我不确定我的想法是否正确。
SELECT A.RESOURCEID,B.PERIOD
FROM
TABLE1 A CROSS JOIN TABLE2 B
UNION ALL
SELECT RESOURCEID,PERIOD
FROM TABLE3 C
GROUP BY RESOURCEID,PERIOD
HAVING COUNT(*)>1http://www.sqlfiddle.com/#!4/36667/2
https://stackoverflow.com/questions/16413349
复制相似问题