- 学习:知识的初次邂逅
- 复习:知识的温故知新
- 练习:知识的实践应用
目录
一,原题力扣链接
二,题干
院系表:
Departments
+---------------+---------+ | Column Name | Type | +---------------+---------+ | id | int | | name | varchar | +---------------+---------+ 在 SQL 中,id 是该表的主键 该表包含一所大学每个院系的 id 信息学生表:
Students
+---------------+---------+ | Column Name | Type | +---------------+---------+ | id | int | | name | varchar | | department_id | int | +---------------+---------+ 在 SQL 中,id 是该表的主键 该表包含一所大学每个学生的 id 和他/她就读的院系信息找出那些所在院系不存在的学生的 id 和姓名
可以以 任何顺序 返回结果。
下面是返回结果格式的例子。
示例 1:
输入: Departments 表: +------+--------------------------+ | id | name | +------+--------------------------+ | 1 | Electrical Engineering | | 7 | Computer Engineering | | 13 | Bussiness Administration | +------+--------------------------+ Students 表: +------+----------+---------------+ | id | name | department_id | +------+----------+---------------+ | 23 | Alice | 1 | | 1 | Bob | 7 | | 5 | Jennifer | 13 | | 2 | John | 14 | | 4 | Jasmine | 77 | | 3 | Steve | 74 | | 6 | Luis | 1 | | 8 | Jonathan | 7 | | 7 | Daiana | 33 | | 11 | Madelynn | 1 | +------+----------+---------------+ 输出: +------+----------+ | id | name | +------+----------+ | 2 | John | | 7 | Daiana | | 4 | Jasmine | | 3 | Steve | +------+----------+ 解释: John, Daiana, Steve 和 Jasmine 所在的院系分别是 14, 33, 74 和 77, 其中 14, 33, 74 和 77 并不存在于院系表
三,建表语句
Create table If Not Exists Departments (id int, name varchar(30))
Create table If Not Exists Students (id int, name varchar(30), department_id int)
Truncate table Departments
insert into Departments (id, name) values ('1', 'Electrical Engineering')
insert into Departments (id, name) values ('7', 'Computer Engineering')
insert into Departments (id, name) values ('13', 'Bussiness Administration')
Truncate table Students
insert into Students (id, name, department_id) values ('23', 'Alice', '1')
insert into Students (id, name, department_id) values ('1', 'Bob', '7')
insert into Students (id, name, department_id) values ('5', 'Jennifer', '13')
insert into Students (id, name, department_id) values ('2', 'John', '14')
insert into Students (id, name, department_id) values ('4', 'Jasmine', '77')
insert into Students (id, name, department_id) values ('3', 'Steve', '74')
insert into Students (id, name, department_id) values ('6', 'Luis', '1')
insert into Students (id, name, department_id) values ('8', 'Jonathan', '7')
insert into Students (id, name, department_id) values ('7', 'Daiana', '33')
insert into Students (id, name, department_id) values ('11', 'Madelynn', '1')
四,分析
解法一:使用左连接: 连接完这2个表 然后保留是null的值 最后去id即可
select Students.id as id,Students.name as name
from Students left join departments on Students.department_id=Departments.id
where Departments.id is null;
解法二: 用子查询, id not in (select id from students) 即可
select
id,name
from Students
where department_id not in (select id from Departments);
五,SQL解答
#解法一
select
id,name
from Students
where department_id not in (select id from Departments);
#解法二:
select Students.id as id,Students.name as name
from Students left join departments on Students.department_id=Departments.id
where Departments.id is null;
六,验证
七,知识点总结
- 左连接的运用
- is null 的运用
- 子查询的运用
- 学习:知识的初次邂逅
- 复习:知识的温故知新
- 练习:知识的实践应用