演示SQL中的并运算

举报
howard2005 发表于 2022/05/26 23:49:47 2022/05/26
【摘要】 文章目录 一、数据库系统二、VFP支持集合的并运算三、SQL查询案例演示(一)查询选修了c120或c140课程或二者都选修了的学生学号、课程号和成绩。方法一、简单查询方法二、利用集合的并运算 ...

一、数据库系统

在这里插入图片描述

二、VFP支持集合的并运算

  • 有时候,用户希望在SQL查询中利用关系代数中的集合运算(并、交、差)来组合关系,SQL为此提供了相应的运算符:UNION、INTERSECT、EXCEPT(Oracle的minus?),分别对应于集合运算的∪、∩、-。它们用于两个查询之间,对每个查询都要用圆括号括起来。对于不同的DBMS,支持的集合运算有所不同,如ACCESS、SQL SERVER、VFP都不支持集合的交运算和差运算。VFP支持集合的并运算,不支持集合的交运算和差运算。

三、SQL查询案例演示

(一)查询选修了c120或c140课程或二者都选修了的学生学号、课程号和成绩。

方法一、简单查询

select 学号,课程号 成绩;
   from 选课表;
   where 课程号 in ("c120","c140")

  
 
  • 1
  • 2
  • 3
  • 查看查询结果
    在这里插入图片描述

方法二、利用集合的并运算

select 学号,课程号,成绩;
   from 选课表;
   where 课程号="c120";
 union;
 select 学号,课程号,成绩;
   from 选课表;
   where 课程号="c140"

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 查看查询结果
    在这里插入图片描述
select 学号,课程号,成绩;
   from 选课表;
   where 课程号="c120";
 union all;
 select 学号,课程号,成绩;
   from 选课表;
   where 课程号="c140"

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 查看查询结果
    在这里插入图片描述

(二)查询同时选修了c120和c140课程的学生学号、课程号和成绩。

  • 可以看出,同时选修c120和c140课程的有s0201105与s0201106。
    在这里插入图片描述
    在这里插入图片描述

  • 怎么利用SQL命令来完成该任务呢?

select 学号,课程号,成绩;
   from 选课表;
   where 学号 in (select 学号 from 选课表 where 课程号="c120");
    and 学号 in (select 学号 from 选课表 where 课程号="c140")

  
 
  • 1
  • 2
  • 3
  • 4
  • 查看查询结果
    在这里插入图片描述

(三)查询选修了c120但是没有选修c140课程的学生学号、课程号和成绩。

select 学号,课程号,成绩;
   from 选课表;
   where 学号 in (select 学号 from 选课表 where 课程号="c120");
    and 学号 not in (select 学号 from 选课表 where 课程号="c140")

  
 
  • 1
  • 2
  • 3
  • 4
  • 查看查询结果
    在这里插入图片描述

文章来源: howard2005.blog.csdn.net,作者:howard2005,版权归原作者所有,如需转载,请联系作者。

原文链接:howard2005.blog.csdn.net/article/details/124974201

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。