SQL 交叉连接问题
我的 SQL 查询遇到了一些问题。
我有两个表:
表 1
id guid title D0 D1 D2
-----------------------------------------
1 guid1 Title1 0.123 -0.235 0.789
2 guid2 Title2 -0.343 0.435 0.459
3 guid3 Title3 0.243 -0.267 -0.934
...
100 guid4 Title100 -0.423 0.955 0.029
和表 2(请注意,它具有相同的架构,只是数据不同)。
id guid title D0 D1 D2
----------------------------------------
1 guid1 Title1 0.233 -0.436 -0.389
2 guid2 Title2 -0.343 0.235 0.789
3 guid3 Title3 0.573 -0.067 -0.124
...
100 guid4 Title100 -0.343 0.155 0.005
我试图弄清楚如何编写一个 SELECT
语句,该语句返回所有标题 WHERE
ABS(Table1_D0*Table2_D0)+ABS(Table1_D1* Table2_D1)+ABS(Table1_D2*Table2_D2)
小于阈值(可能是硬编码)。
到目前为止,我正在尝试使用CROSS JOIN
,但我不确定这是否是正确的方法。
这有道理吗? Table1, row1 对应于 Table2 的所有行,然后 Table1, row2 对应于 Table2 的所有行。
如果重要的话,我正在使用 MS SQL。
非常感谢! 布雷特
I am having a bit of trouble with my SQL query.
I have two tables:
Table1
id guid title D0 D1 D2
-----------------------------------------
1 guid1 Title1 0.123 -0.235 0.789
2 guid2 Title2 -0.343 0.435 0.459
3 guid3 Title3 0.243 -0.267 -0.934
...
100 guid4 Title100 -0.423 0.955 0.029
and Table 2 (note it has the same schema, just different data).
id guid title D0 D1 D2
----------------------------------------
1 guid1 Title1 0.233 -0.436 -0.389
2 guid2 Title2 -0.343 0.235 0.789
3 guid3 Title3 0.573 -0.067 -0.124
...
100 guid4 Title100 -0.343 0.155 0.005
I am trying to figure out how to write a SELECT
statement which returns all the titles WHERE
all the combinations of ABS(Table1_D0*Table2_D0)+ABS(Table1_D1*Table2_D1)+ABS(Table1_D2*Table2_D2)
are less than a thresholded value (hard coded probably).
So far I am trying to use a CROSS JOIN
, but I am not sure if this is the correct approach.
Does this make sense? Table1, row1 against all the rows of Table2, then Table1, row2 against all the rows of Table2.
If it matters, I am using MS SQL.
Many thanks!
Brett
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(4)
CROSS JOIN 是正确的选择,CROSS JOIN 与根本没有连接相同(请参阅 Snowbear 答案)。
CROSS JOIN is the right choice and CROSS JOIN is just the same as no join at all (see Snowbear answer).