数据库力扣刷题(组合两个表)

知识点

一个概念:架构,架构是指用于存储数据库对象的一个命名空间。用于管理数据库对象子集,这样极大的方便地方便并简化了管理数据库对象。

175.组合两个表

题目描述:编写一个SQL查询来报告 Person 表中每个人的姓、名、城市和州。如果 personId 的地址不在 Address 表中,则报告为空 null 。

以 任意顺序 返回结果表。

sql 复制代码
Person表
 +-------------+---------+
| 列名         | 类型     |
+-------------+---------+
| PersonId    | int     |
| FirstName   | varchar |
| LastName    | varchar |
+-------------+---------+
personId 是该表的主键列。
该表包含一些人的 ID 和他们的姓和名的信息。
sql 复制代码
Address表
+-------------+---------+
| 列名         | 类型    |
+-------------+---------+
| AddressId   | int     |
| PersonId    | int     |
| City        | varchar |
| State       | varchar |
+-------------+---------+
addressId 是该表的主键列。
该表的每一行都包含一个 ID = PersonId 的人的城市和州的信息。

知识点:两个表的链接中,无非要用到如下几个

left join: 左连接,形如A left join B ,即查询结果为包含A的全部,B中没有的值就为NULL

right join: 右连接,形如A right join B,取B全部,A没有对应的值,则为NULL

inner join:内连接,形如A inner join B,取交集

full outer join:全连接,形如A full outer join B:取并集,彼此没有对应的值为null

之后如果有查询条件则为:on后面加条件

sql 复制代码
select FirstName,LastName,City,State from Person p left join Address a on p.PersonId=a.PersonId
相关推荐
2501_941111333 分钟前
使用Python处理计算机图形学(PIL/Pillow)
jvm·数据库·python
♡喜欢做梦5 分钟前
MyBatis操作数据库(入门)
java·数据库·mybatis
敲上瘾19 分钟前
MySQL事务全攻略:ACID特性、隔离级别与并发控制
linux·数据库·mysql·安全
懒羊羊不懒@32 分钟前
【MySQL | 基础】事务
数据库·mysql
lucky_syq34 分钟前
再谈向量数据库:AI时代的存储新引擎
大数据·数据库·人工智能
v***446735 分钟前
【Mysql】:如何恢复误删的数据?
数据库·mysql
x***010636 分钟前
使用 MySQL 从 JSON 字符串提取数据
mysql·oracle·json
b***676439 分钟前
使用 Canal 实时从 MySql 向其它库同步数据
数据库·mysql
2501_9411113740 分钟前
Django全栈开发入门:构建一个博客系统
jvm·数据库·python
枫叶丹41 小时前
【Qt开发】Qt窗口(二) -> QToolBar工具栏
开发语言·数据库·c++·qt