SQL每日一题:组合两个表

题干

表: Person

±------------±--------+

| 列名 | 类型 |

±------------±--------+

| PersonId | int |

| FirstName | varchar |

| LastName | varchar |

±------------±--------+

personId 是该表的主键(具有唯一值的列)。

该表包含一些人的 ID 和他们的姓和名的信息。

表: Address

±------------±--------+

| 列名 | 类型 |

±------------±--------+

| AddressId | int |

| PersonId | int |

| City | varchar |

| State | varchar |

±------------±--------+

addressId 是该表的主键(具有唯一值的列)。

该表的每一行都包含一个 ID = PersonId 的人的城市和州的信息。

编写解决方案,报告 Person 表中每个人的姓、名、城市和州。如果 personId 的地址不在 Address 表中,则报告为 null 。以 任意顺序 返回结果表。结果格式如下所示。

示例

解答

简单的左链接便可以处理

sql 复制代码
select firstname ,lastname,city,state from person as p 
left join address as a on p.personid=a.personid
相关推荐
工业甲酰苯胺10 分钟前
使用 C# 和 SQL Server 自动化邮件中的用户分配数据处理
数据库·c#·自动化
Antoine-zxt13 分钟前
MySQL数据脱敏技术全解析:从原理到可视化实践
数据库·mysql
DemonAvenger17 分钟前
深入Redis Stream:打造高效消息队列系统的实战指南
数据库·redis·性能优化
萧曵 丶17 分钟前
MySQL Undo/Redo Log详解
数据库·mysql
虎啊兄弟26 分钟前
RocketMQ面试题
数据库·rocketmq
J_liaty27 分钟前
MySQL EXPLAIN 深度解析与 SQL 优化实战
数据库·sql·mysql
W001hhh28 分钟前
数据库实训Day005上午
数据库
源代码•宸31 分钟前
goframe框架签到系统项目开发(补签逻辑实现、编写Lua脚本实现断签提醒功能、简历示例)
数据库·后端·中间件·go·lua·跨域·refreshtoken
9稳37 分钟前
基于PLC的垃圾车自动收集装置控制系统设计
开发语言·网络·数据库·嵌入式硬件·plc
闲人编程40 分钟前
电商平台用户系统API设计
数据库·后端·消息队列·fastapi·监控·容器化·codecapsule