首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >leet-code两表求合查询

leet-code两表求合查询

作者头像
兔云小新LM
发布于 2022-11-21 12:50:12
发布于 2022-11-21 12:50:12
62800
代码可运行
举报
运行总次数:0
代码可运行

试题要求

编写一个SQL查询来报告Person表中每个人的姓、名、城市和州。如果personId的地址不在Address表中,则报告为空null 。以 任意顺序 返回结果表。

SQL语句

表结构

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
表Person
+-------------+---------+
| 列名         | 类型     |
+-------------+---------+
| PersonId    | int     |
| FirstName   | varchar |
| LastName    | varchar |
+-------------+---------+
personId 是该表的主键列。
该表包含一些人的 ID 和他们的姓和名的信息。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
表Address
+-------------+---------+
| 列名         | 类型    |
+-------------+---------+
| AddressId   | int     |
| PersonId    | int     |
| City        | varchar |
| State       | varchar |
+-------------+---------+
addressId 是该表的主键列。
该表的每一行都包含一个 ID = PersonId 的人的城市和州的信息。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
输入: 
Person表:
+----------+----------+-----------+
| personId | lastName | firstName |
+----------+----------+-----------+
| 1        | Wang     | Allen     |
| 2        | Alice    | Bob       |
+----------+----------+-----------+
Address表:
+-----------+----------+---------------+------------+
| addressId | personId | city          | state      |
+-----------+----------+---------------+------------+
| 1         | 2        | New York City | New York   |
| 2         | 3        | Leetcode      | California |
+-----------+----------+---------------+------------+
输出: 
+-----------+----------+---------------+----------+
| firstName | lastName | city          | state    |
+-----------+----------+---------------+----------+
| Allen     | Wang     | Null          | Null     |
| Bob       | Alice    | New York City | New York |
+-----------+----------+---------------+----------+
解释: 
地址表中没有 personId = 1 的地址,所以它们的城市和州返回 null。
addressId = 1 包含了 personId = 2 的地址信息。

参考答案

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
select FirstName, LastName, City, State
from Person left join Address
on Person.PersonId = Address.PersonId

题解

因为表 Address 中的 personId 是表 Person 的外关键字,所以我们可以连接这两个表来获取一个人的地址信息。考虑到可能不是每个人都有地址信息,我们应该使用 outer join 而不是默认的 inner join。参考链接

确定查询结果

题目要求查询所有学生的姓名,学号,课程和成绩信息

select 学号,姓名,课程,成绩

查询结果的列名“学号”、“姓名”,在“学生”表里,列名“课程”、“成绩”在“成绩”表里,所以需要进行多表查询。

哪种联结呢?

涉及到多表查询,在之前的课程《从零学会sql:多表查询》里讲过需要用到联结。

多表的联结又分为以下几种类型:

1)左联结(left join),联结结果保留左表的全部数据

2)右联结(right join),联结结果保留右表的全部数据

3)内联结(inner join),取两表的公共数据

这个题目里要求“所有学生”,而“所有学生”在“学生”表里。为什么不在“成绩”表里呢?

如果有的学生没有选修课程,那么他就不会出现在“成绩”表里,所以“成绩”表没有包含“所有学生”。

所以要以“学生”表进行左联结,保留左边表(学生表)里的全部数据。

from 学生信息表 as a left join 成绩表 as b

两个表联结条件是什么?

两个表都有“学号”,所以联结条件为学号。

on a.学号=b.学号

相关知识

join连接分为三种,1内连接,2外连接,3交叉连接;

  1. inner join ,默认,所以可以省略inner关键字。
  2. left outer join ,左外连接,结果表中除了匹配行外,还包括左表有而右表中不匹配的行,对于这样的行,右表选择列置为null right outer join ,右外连接,结果表中除了匹配行外,还包括右表有而左表中不匹配的行,对于这样的行,左表选择列置为null natural join,自然连接,分为natural left outer join和natural right outer join,语义定义与inner join相同。
  3. cross join,交叉连接,实际上就是将两个表进行笛卡尔积运算,结果表的行数等于两表行数之积
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-08-12,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 卡二条的技术圈 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
日志框架的引入(slf4j+logback)
用户11288958
2025/08/11
1460
日志框架的引入(slf4j+logback)
配置文件logback-spring.xml
SpringBoot工程自带logback和slf4j的依赖,所以重点放在编写配置文件上,需要引入什么依赖,日志依赖冲突统统都不需要我们管了。
赵哥窟
2022/06/12
1.4K0
配置文件logback-spring.xml
轻量级日志平台
常用的日志管理平台如efk,elk等都太过臃肿,推荐一个轻量级的日志平台zincsearch
用户1599145
2024/03/25
4380
《手把手教你》系列基础篇(九十)-java+ selenium自动化测试-框架设计基础-Logback实现日志输出-中篇(详解教程)
上一篇宏哥介绍是如何使用logback将日志输出到控制台中,但是如果需要发给相关人需要你拷贝出来,有时候由于控制台窗口的限制,有部分日志将会无法查看,因此我们还是需要将日志输出到文件中,因此今天主要介绍和分享如何使用logback将日志输出到文件中。
北京-宏哥
2022/04/27
3180
《手把手教你》系列基础篇(九十)-java+ selenium自动化测试-框架设计基础-Logback实现日志输出-中篇(详解教程)
logback日志入门超级详细讲解
日志:就是能够准确无误地把系统在运行状态中所发生的情况描述出来(连接超时、用户操作、异常抛出等等); 日志框架:就是集成能够将日志信息统一规范后输出的工具包。
呆呆
2021/10/09
2.8K0
电商网站开发记录(四) logback.xml配置以及初始代码提交
1.logback.xml <?xml version="1.0" encoding="UTF-8"?> <configuration scan="true" scanPeriod="60 secon
Dar_Alpha
2018/09/03
4700
SpringBoot 的 logback 日志配置
1. 在 resources 目录下创建日志的配置文件 logback-spring.xml , 这是 SpringBoot 官方约定的名称
北漂的我
2020/07/03
8460
SpringBoot——配置logback日志
介绍: 在项目运行中,我们需要对项目的出错或运行有了解,可以通过日志文件的查看来实现。因此,项目日志的打印就至关重要。本文给出一种logback日志的配置。改配置会在每天进行整理,同时区分不同的日志级别进行记录。
凡人飞
2020/09/21
2.4K0
SpringBoot——配置logback日志
SpringBoot 使用Logback日志框架
项目中日志系统是必不可少的,目前比较流行的日志框架有log4j、logback等,可能大家还不知道,这两个框架的作者是同一个人,Logback旨在作为流行的log4j项目的后续版本,从而恢复log4j离开的位置。另外 slf4j(Simple Logging Facade for Java) 则是一个日志门面框架,提供了日志系统中常用的接口,logback 和 log4j 则对slf4j 进行了实现。我们本文将讲述如何在spring boot 中应用 logback+slf4j实现日志的记录。
鱼找水需要时间
2023/02/16
7270
logback 配置
(adsbygoogle = window.adsbygoogle || []).push({});
yawn
2019/06/15
8790
Logback日志这样配置,让你性能提升10倍!
SpringBoot工程自带 logback和 slf4j的依赖,所以重点放在编写配置文件上,需要引入什么依赖,日志依赖冲突统统都不需要我们管了。logback框架会默认加载 classpath下命名为 logback-spring或 logback的配置文件。
用户1263954
2022/02/15
3.7K0
Logback日志这样配置,让你性能提升10倍!
logback 日志输出格式
强烈推荐一个大神的人工智能的教程:http://www.captainbed.net/zhanghan
全栈程序员站长
2022/06/28
1.2K0
logback 日志输出格式
Springboot日志管理——logback
当我们启动springboot的时候,控制台的默认输出就是由logback完成的。
Tom2Code
2022/11/21
8300
Springboot日志管理——logback
logback.xml配置详解
<?xml version="1.0" encoding="UTF-8"?> <!-- 日志级别从低到高分为TRACE < DEBUG < INFO < WARN < ERROR < FATAL,比如
JQ实验室
2022/03/18
2.8K0
logback 配置文件
本文由 小马哥 创作,采用 知识共享署名4.0 国际许可协议进行许可 本站文章除注明转载/出处外,均为本站原创或翻译,转载前请务必署名 最后编辑时间为: 2022/05/04 19:38
IT小马哥
2022/05/05
1.1K0
概念,原理,到例子,全解析logback ,学会日志系统
在业务系统开发中,一般使用的日志框架有 Commons logging 、 Log4j 、 Slf4j 、 Logback 、 Log4j 2 等。
香菜聊游戏
2021/07/15
3K0
一文读懂Springboot日志框架
Trace-> debug-> info-> warn-> error-> fatal
QGS
2024/01/19
1.9K0
细说Java主流日志工具库
概述 在项目开发中,为了跟踪代码的运行情况,常常要使用日志来记录信息。 在Java世界,有很多的日志工具库来实现日志功能,避免了我们重复造轮子。 我们先来逐一了解一下主流日志工具。 java.util
静默虚空
2018/01/05
1.4K0
细说Java主流日志工具库
详解 Java 主流日志工具库
在项目开发中,为了跟踪代码的运行情况,常常要使用日志来记录信息。在 Java 世界,有很多的日志工具库来实现日志功能,避免了我们重复造轮子。先来逐一了解一下主流日志工具。
JavaFish
2019/11/13
1.1K0
SpringBoot基础(三):Logback日志
适配器作用:以后想要换其他日志框架,只要排除掉logback日志实现,导入log4j2或jul的日志实现即可,代码中API还是slf4j不需要修改,只修改maven依赖就改变了日志的底层实现。
Java微观世界
2025/01/21
6900
SpringBoot基础(三):Logback日志
相关推荐
日志框架的引入(slf4j+logback)
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验