教材 /《数据库系统概念》第六版第三章内容 机械工程出版社;实验软件/Qracle 11g

写在前面

用下面的样例1引出我们讨论的这一类方法。

样例1:使用大学模式,用SQL写出以下查询,实现功能:找出选修了Biology系开设的所有课程的学生。

分析:

首先,我们思考这样一个问题。假设我们将本题中各关系用以下方法定义

A:找出学生所修的所有课程

B:找出所有生物系所开设的课程

思路:

本样例想要的查找结果必然满足:

而相对应的,相差 可以由 minus 实现,为空 可以由 not exists 实现。由此,我们可以写出此查询如下:

select s.ID , s.name
from student s
where not exists
(
(select course_id
from course
where dept_name='Biology')
minus
(select t.course_id
from takes t
where s.ID=t.ID)
);

下面提供一个类似的样例2查询题。

样例2: 考虑如下的图书馆数据库。

member(memb no, name, age)

book(isbn, title, authors, publisher)

borrowed(memb no, isbn, date)

题目要求 用SQL写出如下查询,实现功能:打印借阅了所有由McGraw-Hill出版的书的会员的名字。

select name
from member m
where not exists
( (select isbn
from book
where publisher = 'McGraw_Hill')
minus
(select isbn
from borrowed b
where b.memb_no = m.memb_no));

最新文章

  1. hdu3294 girl‘s research
  2. Atitit 异常机制与异常处理的原理与概论
  3. [Linux] CentOS 加入开机启动
  4. HDU 4647 Another Graph Game 思路+贪心
  5. Symfony2学习笔记之HTTP Cache
  6. Light OJ 1095 Arrange the Numbers(容斥)
  7. window2003远程桌面“已达最大连接数”
  8. c语言内存对齐(1)
  9. JavaScript 中实现继承的方式(列举3种在前一章,我们曾经讲解过创建类的最好方式是用构造函数定义属性,用原型定义方法。)
  10. maven打包 bat自动化打包
  11. eclipse在多modules项目结构下避免模块间依赖引用的场景
  12. OCM_第十三天课程:Section6 —》数据库性能调优 _结果缓存 /多列数据信息采集统计/采集数据信息保持游标有效
  13. 探Java多线程Thread类和Runnable接口之间的联系
  14. C#转换成Json的方法集
  15. 二、git版本回退
  16. iOS 基础入门--Bull' Eye 小游戏 
  17. CTF-Bugku-分析-信息提取
  18. solaris如何启动ssh服务
  19. C语言调用Cmd命令以及执行系统软件
  20. python循环,函数

热门文章

  1. JSP/Servlet Web 学习笔记 DayThree
  2. J2EE的十三个技术——Servlet
  3. 写把proto函数搞清楚
  4. Angular & RxJS & Typesc­ript
  5. 【bzoj3325】[Scoi2013]密码 逆模拟Manacher
  6. 【bzoj4177】Mike的农场 网络流最小割
  7. java 符号引用与直接引用
  8. HDU 1867 A + B for you again ----KMP
  9. xen save/restore 过程
  10. 一篇不错的v4l2入门文档【转】