gpt4 book ai didi

sql - FROM CLAUSE (SQL) 中的此 SQL 语句中的括号是做什么的

转载 作者:行者123 更新时间:2023-12-02 06:53:31 36 4
gpt4 key购买 nike

第 5 行和第 11 行的括号是做什么用的?

 1    SELECT
2 s.name, s.ShirtDescription, c.Color,
3 z.Size, i.AvailableQTY, i.UnitPrice
4 FROM
5 (
6 test.ShirtInventory i
7 join test.Colors c ON
8 i.ColorID = c.id
9 join test.Shirts s ON
10 i.ShirtID = s.ID
11 )
12 JOIN test.Sizes z ON
13 i.SizeID = z.ID
14 WHERE .....

我从未见过在 FROM 子句中以这种方式使用括号。这不是子查询,也不是表和连接的范围。您可以看到我在括号外引用 i.SizeID 的地方。当我第一次看到它时,我认为这可能是一种向 SQL Server“提示”您希望如何获取数据的方法,但是当您删除括号时执行计划没有任何变化。

期待您的回复。编辑:行错了

最佳答案

在这种情况下没有任何内容,因为内部联接是关联的和可交换的。

一般来说,您可以通过移动 on 子句的位置来更改参与连接的虚拟表,这也可以应用可选的括号,希望让事情变得更清楚。

所以 for example你可以

SELECT P.PersonName,
Pt.PetName,
Pa.AccessoryName
FROM Persons P
LEFT JOIN Pets Pt
INNER JOIN PetAccessories Pa
ON Pt.PetName = Pa.PetName
ON P.PersonName = Pt.PersonName;

也可以选择写入

SELECT P.PersonName,
Pt.PetName,
Pa.AccessoryName
FROM Persons P
LEFT JOIN (Pets Pt
INNER JOIN PetAccessories Pa
ON Pt.PetName = Pa.PetName)
ON P.PersonName = Pt.PersonName;

关于sql - FROM CLAUSE (SQL) 中的此 SQL 语句中的括号是做什么的,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36900883/

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