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

数据库系统概论(十一)SQL 集合查询 超详细讲解(附带例题表格对比带你一步步掌握)

数据库系统概论(十一)SQL 集合查询 超详细讲解(附带例题表格对比带你一步步掌握)

  • 前言
  • 一、什么是集合查询?
  • 二、集合操作的三种类型
    • 1. 并操作
    • 2. 交操作
    • 3. 差操作
  • 三、使用集合查询的前提条件
  • 四、常见问题与注意事项
  • 五、总结


前言

  • 在前几期博客中,我们探讨了 SQL 连接查询,单表查询,嵌套查询技术等知识点。
  • 从本节开始,我们将深入讲解 SQL 中SQL 集合查询的知识点。

我的个人主页,欢迎来阅读我的其他文章
https://blog.csdn.net/2402_83322742?spm=1011.2415.3001.5343
我的数据库系统概论专栏
https://blog.csdn.net/2402_83322742/category_12911520.html?spm=1001.2014.3001.5482


一、什么是集合查询?

集合查询就是把多个查询结果像“拼积木”一样组合起来,就像班级里不同小组的同学合并、找交集或找差异
比如:

  • 想找“计算机专业学生”和“年龄≤19岁学生”的合并名单 → 用并操作
  • 想找“同时选修了课程A和课程B的学生” → 用交操作
  • 想找“计算机专业但年龄>19岁的学生” → 用差操作

在这里插入图片描述

二、集合操作的三种类型

1. 并操作

作用:合并两个查询结果,自动去重(类似“+”号)。
语法

SELECT1,2 FROMWHERE 条件1  
UNION  
SELECT1,2 FROMWHERE 条件2;  

例子
查询“计算机科学与技术专业学生”或“年龄≤19岁学生”的所有记录:

SELECT * FROM Student WHERE Smajor='计算机科学与技术'  
UNION  
SELECT * FROM Student WHERE Sage<=19;  

注意

  • 若想保留重复记录,用 UNION ALL(不去重)。
  • 两张表的列数必须相同,对应列的数据类型必须一致(比如都是数字或文本)。

2. 交操作

作用:找出两个查询结果中共同的部分(类似“∩”)。
语法

SELECT1,2 FROMWHERE 条件1  
INTERSECT  
SELECT1,2 FROMWHERE 条件2;  

例子
查询“既是计算机专业,又年龄≤19岁的学生”:

SELECT * FROM Student WHERE Smajor='计算机科学与技术'  
INTERSECT  
SELECT * FROM Student WHERE timestampdiff(year, Sbirthday, curdate())<=19;  

替代方法:用子查询实现交操作(适用于不支持INTERSECT的数据库):

SELECT * FROM Student  
WHERE Smajor='计算机科学与技术'  
AND Sno IN (SELECT Sno FROM Student WHERE Sage<=19);  

3. 差操作

作用:从第一个查询结果中排除第二个查询的结果(类似“-”)。
语法

SELECT1,2 FROMWHERE 条件1  
EXCEPT  
SELECT1,2 FROMWHERE 条件2;  

例子
查询“计算机专业,但年龄>19岁的学生”:

SELECT * FROM Student WHERE Smajor='计算机科学与技术'  
EXCEPT  
SELECT * FROM Student WHERE Sage<=19;  

替代方法:用条件筛选实现差操作:

SELECT * FROM Student  
WHERE Smajor='计算机科学与技术' AND Sage>19;  

三、使用集合查询的前提条件

  1. 列数必须相同
    比如第一个查询选2列(姓名、年龄),第二个查询也必须选2列,不能一个选2列、一个选3列。
  2. 对应列的数据类型必须一致
    比如第一个查询的第一列是“姓名(文本)”,第二个查询的第一列也必须是文本类型,不能是数字。

四、常见问题与注意事项

  1. 数据库兼容性
    • INTERSECTEXCEPT在MySQL中不直接支持,需用子查询或JOIN替代(如上文中的替代方法)。
    • 在SQL Server、Oracle等数据库中可直接使用。
  2. 性能考虑
    • 简单场景下,子查询(如IN)可能比集合操作更易理解和优化。
    • 复杂场景下,集合操作可能更高效(需根据具体数据库优化)。

五、总结

  • UNION(并):把两组人“合在一起”,去重(或保留重复)。
  • INTERSECT(交):找两组人里“同时存在的人”。
  • EXCEPT(差):从第一组人里“去掉”第二组的人。

以上就是这篇博客的全部内容,下一篇我们将继续探索更多精彩内容。

我的个人主页,欢迎来阅读我的其他文章
https://blog.csdn.net/2402_83322742?spm=1011.2415.3001.5343
我的数据库系统概论专栏
https://blog.csdn.net/2402_83322742/category_12911520.html?spm=1001.2014.3001.5482

非常感谢您的阅读,喜欢的话记得三连哦

在这里插入图片描述


文章转载自:

http://NFvxVkUq.wjqbr.cn
http://JMyC0eHh.wjqbr.cn
http://Xf3oQkpL.wjqbr.cn
http://PpM6KQGs.wjqbr.cn
http://K2FDw3Wj.wjqbr.cn
http://Xh7zIezG.wjqbr.cn
http://R3YA7Z6W.wjqbr.cn
http://k0GwJWXp.wjqbr.cn
http://wCFMKn98.wjqbr.cn
http://iSc6EEx5.wjqbr.cn
http://zDuPoZN6.wjqbr.cn
http://JAC410Rs.wjqbr.cn
http://bhpCijAJ.wjqbr.cn
http://HNytSPH9.wjqbr.cn
http://34GSMhLk.wjqbr.cn
http://ECUbMf7M.wjqbr.cn
http://ORC8Jxbj.wjqbr.cn
http://MBZpazmY.wjqbr.cn
http://bhHdS0zR.wjqbr.cn
http://c0ThHv2Y.wjqbr.cn
http://NP81nuHW.wjqbr.cn
http://GPDbVdWq.wjqbr.cn
http://bCugj59r.wjqbr.cn
http://ClJo21Bu.wjqbr.cn
http://vaOX3F0K.wjqbr.cn
http://uylNasvk.wjqbr.cn
http://ZtNP8lG7.wjqbr.cn
http://RtKH2ULC.wjqbr.cn
http://le8ZJueJ.wjqbr.cn
http://YHAA5nWF.wjqbr.cn
http://www.dtcms.com/a/226707.html

相关文章:

  • Golang——5、函数详解、time包及日期函数
  • 编译原理实验 之 TINY 之 语义分析(第二次作业)
  • 第九章:LLMOps自动化流水线:释放CI/CD/CT的真正力量
  • SQL 中的 `CASE WHEN` 如何使用?
  • AI书签管理工具开发全记录(九):用户端页面集成与展示
  • 排序算法——详解
  • 4.大语言模型预备数学知识
  • 【iOS(swift)笔记-13】App版本不升级时本地数据库sqlite更新逻辑一
  • 企业展示型网站模板HTML5网站模板下载指南
  • PostgreSQL 在生物信息学中的应用
  • Java并发编程实战 Day 4:线程间通信机制
  • 网络节点排查
  • cpper 转 Golang
  • 家政维修平台实战12搭建服务详情功能
  • 实现按天更新vintage并热力图可视化
  • 如何用AI写作?
  • SQL Views(视图)
  • SQL快速入门【转自牛客网】
  • MCP协议学习
  • Transformer核心技术深度解析:多头注意力机制与架构精粹
  • 20250602在荣品的PRO-RK3566开发板的Android13下打开关机对话框
  • 【Linux】网络--网络层--IP协议
  • 抖音商城抓包 分析
  • 基于Python学习《Head First设计模式》第三章 装饰者模式
  • Android基于LiquidFun引擎实现软体碰撞效果
  • leetcode hot100刷题日记——35.子集
  • day17 leetcode-hot100-34(链表13)
  • 每日算法刷题计划Day20 6.2:leetcode二分答案3道题,用时1h20min
  • 从 LeetCode 到日志匹配:一行 Swift 实现规则识别
  • 力扣LeetBook数组和字符串--数组简介