SQL常见技巧:巧用自连接

本文解析了如何通过SelfJoin实现查询同时选修编号为01和02课程的学生信息,强调了自连接在处理同时使用列中两个值的问题上的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

文章目录


注:Self Join 自连接的另一种做法是关联子查询

题目一

查询学过编号为“01”的课程并且也学过编号为“02”的课程的学生的学号、姓名

SELECT st.s_id, st.s_name
FROM Student st 
JOIN 
		(
		SELECT sc1.* 
		FROM Score sc1 
		JOIN Score sc2 
		ON sc1.s_id = sc2.s_id
		WHERE sc1.c_id = '01'     # 这里不需要使用IN,也不需要纠结顺序问题,因为两张表都是Score
					AND sc2.c_id = '02'
		) m 
ON st.s_id = m.s_id;

小结

这种题目的特点就是,同时使用了一列数据中的两个值,像这种情况就可以考虑使用自连接(还有一种可能是使用条件语句进行行转列)。

一般来说,最常见的连接的条件是两个值相等,再就是题目二中的”均包含“。

补:

注意自连接的具体形式,看下图,并不是简单的机械拼接,而是以条件查找的方式进行遍历循环!!!

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值