gpt4 book ai didi

sql - PostgreSQL 多个 USING 子句

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

我经常发现自己在 中使用(没有双关语)USING 子句PostgreSQL ,并且想知道在同一个键名上有多个 USING 的情况下如何进行选择。
让我用一个简单的例子来解释:
让表 A、B 和 C 具有 userid 列。
如果我在做:

SELECT A.c1, A.c2, ...
FROM A
JOIN B USING(userid)
JOIN C USING(userid) ;
Postrges 如何管理由于表 B 和 C 都具有列 userid 而产生的冲突?产生的输出是什么?
A.userid = B.userid AND A.userid = C.userid
或者
A.userid = B.userid AND B.userid = C.userid 
我希望我已经足够清楚,预先感谢您的回答。
PS:我没有做多个 USING 子句,因为我发现它不可读,但我想知道它是如何工作的。

最佳答案

使用内部联接,此查询:

SELECT A.c1, A.c2, ...
FROM A JOIN
B
USING (userid) JOIN
C
USING (userid) ;
相当于:
SELECT A.c1, A.c2, ...
FROM A JOIN
B
ON B.userid = A.userid JOIN
C
ON C.userid = A.userid ; -- or "C.userid = B.userid", it doesn't matter
请注意 NULL值未通过 INNER JOIN 的比较,所以它们不是问题,因为它们不在结果集中。
对于 LEFT OUTER JOIN ,逻辑和上面一样。对于 FULL JOIN :
SELECT A.c1, A.c2, ...
FROM A FULL JOIN
B
ON B.userid = A.userid FULL JOIN
C
ON C.userid = COALESCE(A.userid, B.userid) ;
请注意,在整个查询的其余部分 userid ,不加限定,指的是非 NULL任何表中的值。

关于sql - PostgreSQL 多个 USING 子句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64060838/

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