当前位置: 首页 > news >正文

查询【学过 001 号同学所有课程】的学生

3 种高性能写法,专门解决:

查询【学过 001 号同学所有课程】的学生

(比双层 NOT EXISTS 更高效、更现代、大厂常用)


🔥 写法 1:GROUP BY + HAVING(最高性能、最简洁

这是大数据量下最快的写法,面试 / 工作首选。

sql

SELECT s.s_no, s.sname FROM Student s JOIN Sc sc ON s.s_no = sc.s_no -- 只查001选过的课程 WHERE sc.c_no IN (SELECT c_no FROM Sc WHERE s_no = '001') AND s.s_no <> '001' GROUP BY s.s_no, s.sname -- 关键:选的课程数 = 001选的总课程数 HAVING COUNT(DISTINCT sc.c_no) = ( SELECT COUNT(DISTINCT c_no) FROM Sc WHERE s_no = '001' );

原理(超简单)

  1. 先把学生只限制在 001 选过的课程
  2. 统计每个学生选了几门
  3. 数量 = 001 选的总课数→ 就是全选了

🔥 写法 2:JOIN 分组匹配(极高速)

适合超大数据量表,性能碾压 NOT EXISTS

sql

SELECT s.s_no, s.sname FROM Student s JOIN ( SELECT sc2.s_no FROM Sc sc1 JOIN Sc sc2 ON sc1.c_no = sc2.c_no WHERE sc1.s_no = '001' GROUP BY sc2.s_no HAVING COUNT(DISTINCT sc2.c_no) = ( SELECT COUNT(DISTINCT c_no) FROM Sc WHERE s_no = '001' ) ) t ON s.s_no = t.s_no WHERE s.s_no <> '001';

🔥 写法 3:WITH 子句(现代 SQL,可读性最强)

MySQL 8.0 / PostgreSQL / SQL Server 通用

sql

WITH Course001 AS ( SELECT DISTINCT c_no FROM Sc WHERE s_no = '001' ), TotalCourse AS ( SELECT COUNT(*) AS total FROM Course001 ) SELECT s.s_no, s.sname FROM Student s JOIN Sc sc ON s.s_no = sc.s_no JOIN Course001 c ON sc.c_no = c.c_no WHERE s.s_no <> '001' GROUP BY s.s_no, s.sname HAVING COUNT(DISTINCT sc.c_no) = (SELECT total FROM TotalCourse);

🚀 三种写法性能对比(直接告诉你用哪个)

表格

写法性能适用场景推荐指数
GROUP BY + HAVING⭐⭐⭐⭐⭐所有场景,首选最强
JOIN 分组⭐⭐⭐⭐⭐千万级大数据极强
WITH 子句⭐⭐⭐⭐现代 SQL、代码清晰优秀
NOT EXISTS⭐⭐教学、小数据一般

✅ 总结一句话

查询 “选了全部 XX 课程”,别用 NOT EXISTS,用 GROUP BY + HAVING 性能最高!

http://www.jsqmd.com/news/768492/

相关文章:

  • 基于OpenClaw-Video-Vision的视频语义检索与理解实战指南
  • 网盘下载革命:直链解析工具如何让你的文件传输快10倍
  • C语言数据结构-11顺序二叉树
  • ClaraVerse开源框架:构建去中心化元宇宙的核心架构与开发实战
  • hermes的UI界面
  • 北京GEO公司哪家靠谱?生成式引擎优化助力品牌数字化转型
  • YOLOv8-Seg实战避坑:从COCO预训练到自定义数据集的迁移学习全记录
  • 山东农业大学考研辅导班机构推荐:排行榜单与哪家好评测 - michalwang
  • DX-BT04-A蓝牙模块AT指令配置全攻略:从改名到改波特率,一篇搞定
  • ABB机器人推出全自动表面处理工作站,打破中小企业自动化壁垒
  • Claude提示工程实战:turbo-claude规则集提升AI应用开发效率
  • Cypress AI智能测试:LLM驱动的自动化脚本生成与维护实践
  • 服务治理与系统韧性:筑牢分布式系统高可用防线
  • 2026年3月浙江艺术职校推荐,艺术职校有哪些哪家可靠宁三技校诚信务实提供高性价比服务 - 品牌推荐师
  • 精准测试:用AI与大数据定位最高风险变更域
  • 免费开源数据库工具 DBeaver 26.0.4 发布,多模块更新解决诸多问题
  • 如何轻松批量下载B站视频?BilibiliDown终极指南免费开源
  • 为你的ROS移动机器人(TurtleBot/无人机)快速集成Livox Mid360仿真模块:一个可复用的Xacro宏教程
  • 本地部署OpenAI TTS兼容API:免费、低延迟的语音合成方案
  • B-52 | The Electromechanical Angle Computer
  • TestDisk PhotoRec:开源数据恢复双雄,480+文件格式的终极拯救方案
  • 终极窗口调整指南:用WindowResizer打破Windows窗口限制的完整解决方案
  • OpenCodeUI:基于React+TypeScript+Tailwind的现代化开源UI组件库
  • C++ 知识点01 命名空间(Namespace)
  • 长春工业大学考研辅导班机构推荐:排行榜单与哪家好评测 - michalwang
  • 2026山东大学软件学院项目实训个人博客(四)
  • 汽车ECU休眠唤醒那些事:从TJA1021的INH引脚到AUTOSAR LinTrcv的唤醒机制全解析
  • mex:现代极简终端编辑器,平衡性能与易用性的新选择
  • OpenCharacters开源框架:构建有记忆的AI角色对话系统
  • 5G NR物理层扫盲:手把手拆解PBCH信道里的MIB消息(附与LTE对比)