175 -組合兩個表- SQL

SQL架構

1: Person

+-------------+---------+
| 列名         | 類型     |
+-------------+---------+
| PersonId    | int     |
| FirstName   | varchar |
| LastName    | varchar |
+-------------+---------+
PersonId 是上表主鍵
2: Address

+-------------+---------+
| 列名         | 類型    |
+-------------+---------+
| AddressId   | int     |
| PersonId    | int     |
| City        | varchar |
| State       | varchar |
+-------------+---------+
AddressId 是上表主鍵

編寫一個 SQL 查詢,滿足條件:無論 person 是否有地址信息,都需要基於上述兩表提供 person 的以下信息:FirstName, LastName, City, State


晚上準備做幾道題。打開Leetcode發現怎麼還有SQL的題……這道題要求最後執行SQL語句後得到的信息有FirstName, LastName, City, State,其中前兩個在表Person中,後兩個在表Address中,兩個表的聯繫是PersonId,因此肯定要用到表的連接。然後再看題目,題目要求無論Address表中的City和State是否爲NULL,都要返回FirstName, LastName, 因此直到這裏要用左連接,連接的點就是PersonId。

SELECT FirstName, LastName, City, State
FROM Person p
LEFT JOIN Address a
on p.PersonId = a.PersonId

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章