我在获取连接条件以隔离唯一记录时遇到问题。我的查询是返回笛卡儿产品,我不知道如何让它停止。我的表看起来像这样:
Table A
ID_1 Start End Name
137 1:00 2:00 Galia
137 2:00 3:00 Est
137 3:00 4:00 Omnia
137 4:00 5:00 Divisa
137 5:00 6:00 Partes
137 6:00 7:00 Tres
137 7:00 8:00 Quarum
137 8:00 9:00 Unam
137 9:00 10:00 Incolunt
Table B
ID_1Time_1 Time_2
137 3:10 3:57
我的疑问是:
select A.*, B.Time_1, B.Time_2
from Table_A A
inner join
Table_B B
on
A.ID_1 = B.ID_1 and B.Time_1<=A.End and B.Time_2 >= A.Start
我得到的是这样的:
ID_1Start End Name Time_1 Time_2
137 1:00 2:00 Galia 3:10 3:57
137 2:00 3:00 Est 3:10 3:57
137 3:00 4:00 Omnia 3:10 3:57
137 4:00 5:00 Divisa 3:10 3:57
137 5:00 6:00 Partes 3:10 3:57
137 6:00 7:00 Tres 3:10 3:57
137 7:00 8:00 Quarum 3:10 3:57
137 8:00 9:00 Unam 3:10 3:57
137 9:00 10:00 Incolunt3:10 3:57
所以看起来它给出了两个表的笛卡尔积,这是有意义的,因为每个记录都满足所有三个条件。我想要的只是返回时间对应的记录,如下所示:
ID_1Start End Name Time_1 Time_2
137 3:00 4:00 Omnia 3:10 3:57
有关如何构建连接以实现此目的的任何建议吗?我正在研究Netezza盒子,如果它有助于提供可用的功能。感谢。
答案 0 :(得分:3)
您希望应用以下条件:
A.Start <= B.Time_1 <= B.Time_2 <= A.End
假设列数据类型是连贯的(即只存储时间,而不是日期时间或时间戳),并且值是一致的(即,上面多重关系中的中心谓词已经有效)。这些条件可以在SQL中重写为
B.Time_2 <= A.End AND B.Time_1 >= A.Start
而不是
B.Time_1 <= A.End and B.Time_2 >= A.Start
可能对应
B.Time_1 <= A.Start <= A.End <= B.Time_2
因此:
select A.*, B.Time_1, B.Time_2
from Table_A A
inner join
Table_B B
on
A.ID_1 = B.ID_1 and B.Time_1>=A.Start and B.Time_2 <= A.End