学生数据库中有三个基本表(关系)如下:

学生表S(Sno,Sname,Age,Sex,SD)

课程表C(Cno,Cname, Teacher)

选课表SC(Sno,Cno,Grade)

请用SQL语言完成以下操作:

(1)检索选修课程名为“数据库系统原理”的学生号和学生姓名。

(2)检索至少选修了课程号为“C1”和“C3”的学生号。

(3)检索选修了“操作系统”或“自动控制原理”课程的学号和成绩。

(4)检索年龄在18到20之间(含18和20)的女生的学号、姓名及年龄。

(5)检索选修了“高博”老师所讲课程的学生的学号、姓名。

(6)检索选修了全部课程的学生姓名。

(7)检索至少选修了学号“S002”的学生选修的全部课程的学生学号。

(8)检索所有姓“蒋”的学生姓名、年龄和所在系。

(9)检索选修了三门课以上的学生姓名、年龄和所在系。

解:以下都是参考代码,仅供参考

--(1)检索选修课程名为“数据库系统原理”的学生号和学生姓名--
--方法1:--
SELECT S.Sno,Sname FROM S,SC,C
WHERE S.Sno=SC.Sno AND SC.Cno=C.Cno AND C.Cname=‘数据库系统原理’ --方法2:--
SELECT Sno,Sname FROM S
WHERE Sno IN (SELECT Sno FROM SC
WHERE Cno IN (SELECT Cno FROM C
WHERE Cname=‘数据库系统原理’))

方法1与方法2就是连接查询和嵌套查询的区别。在方法2中 IN 作为 WHERE 的一个筛选条件,与 = 有一定的区别,两者都是等于的意思,但 IN 可以定义多个值的范围,我们查询的结果只要存在于 IN 的范围中就可被视为符合条件

--(2)检索至少选修了课程号为“C1”和“C3”的学生号--
SELECT Sno FROM SC SCX,SC SCY
WHERE SCX.Sno=SCY.Sno AND SCX.Cno=‘C1’ AND SCY.Cno=‘C3’

根据题意,我们需要在一张表里进行互相的查询,所以为了防止出现 Sno = Sno 这样容易混淆的情况,我们通过 SC SCX,SC SCY ,给选课表SC定义两个别名,利于区分。实际上还是 SC 数据表自己和自己的比较。

--(3)检索选修了“操作系统”或“自动控制原理”课程的学号和成绩--
--方法1:--
SELECT Sno,Grade FROM SC,C
WHERE SC.Cno=C.Cno AND (C.Cname=‘操作系统’OR C.Cname=‘自动控制原理’) --方法2:--
SELECT Sno,Grade FROM SC
WHERE Cno IN (SELECT Cno FROM C
WHERE C.Cname=‘操作系统’OR C.Cname=‘自动控制原理’)

第 (3) 题的思路与第 (1) 题相似,只是把其中一个条件改变为 OR 运算符

--(4)检索年龄在18到20之间(含18和20)的女生的学号、姓名及年龄--
--方法1:--
SELECT Sno,Sname,Age FROM S
WHERE Age>=18 AND Age<=20 AND Sex=‘女’ --方法2:--
SELECT Sno,Sname,Age
FROM S WHERE Age BETWEEN 18 AND 20 AND Sex=‘女’

这道题主要是对于范围的练习,但更推荐使用方法1,因为这样比较清晰地查看查询地范围是否包含边界。BETWEEN …AND 在确定范围中是包含边界的,方法2比较巧妙地利用了这一性质,但如果记忆不清特性,在某些范围查询语句中滥用,就会获得错误的查询结果,因此笔者更推荐方法1的思路。

--(5)检索选修了“高博”老师所讲课程的学生的学号、姓名。--
--方法1:--
SELECT S.Sno,Sname FROM S,SC,C
WHERE S.Sno=SC.Sno AND SC.Cno=C.Cno AND C.Teacher=‘高博’ --方法2:--
SELECT Sno,Sname FROM S
WHERE Sno IN (SELECT Sno FROM SC
WHERE Cno IN (SELECT Cno FROM C
WHERE Teacher=‘高博’))

这道题的思路与第 (1) 题类似,便不赘述了。

--(6)检索选修了全部课程的学生姓名--
SELECT Sname FROM S
WHERE NOT EXISTS (SELECT * FROM C
WHERE NOT EXISTS (SELECT * FROM SC
WHERE Sno=S.Sno AND Cno=C.Cno))

这道题是运用了 EXIST 的嵌套查询,对于查询结果返回 True 或 False,同时在一条语句中使用两个 NOT EXIST 即表示程序的双重否定,第 (6) 题的语意,笔者大致理解为,查找某些学生,对于他们来说,不存在这样一门课,它对应的选课表里面的学号不存在这个学生的学号。

意思可能还是很难理解,但是我们已经可以理出双重否定的语句,双重肯定表否定,且根据逻辑, ┐∃ ≡ ∀ ┐

即:查找某些学生,对于他们来说,任意一门课,它对应的任意的一张选课表里面的学号都存在这个学生的学号

--(7)检索至少选修了学号“S002”的学生选修的全部课程的学生学号--
SELECT Sno FROM SC SCX
WHERE NOT EXISTS (SELECT * FROM SC SCY
WHERE SCY.Sno=‘S002’ AND NOT EXISTS (SELECT * FROM SC SCZ
WHERE SCZ.Sno=SCX.Sno
AND SCZ.Cno=SCY.Cno))

第 (6) 题和第 (2) 题的思路

--(8)检索所有姓“蒋”的学生姓名、年龄和所在系--
SELECT Sname,Age,SD FROM S
WHERE Sname LIKE ‘蒋%’

LIKE 操作符用于在 WHERE 子句中搜索列中的指定模式。

--(9)检索选修了三门课以上的学生姓名、年龄和所在系--
SELECT Sname,Age,SD FROM S
WHERE Sno IN (SELECT Sno FROM SC
GROUP BY Sno HAVING COUNT(*)>3)

WHERE 关键字无法与聚合函数一起使用,HAVING 子句可以让我们筛选分组后的各组数据

分享一下常见的聚合函数: :

以上这些就是此次SQL语句的进阶版,希望你看完能有所收获。

SQL语句练习(进阶版)的更多相关文章

  1. sql 语句-初级进阶(一)

    以下所有的sql语句是根据个人资料进行操作,为方便大家操作联系,附上链接:: 链接:https://pan.baidu.com/s/14LmWyhJPQRzpjURQBKM4mA 提取码:wu1q  ...

  2. sql 语句-初级进阶(二)

    1.insert插入数据时注意事项: 每次插入一整行,不能半行或者是几列数据. 值与列数必须相同,包括数据类型也必须匹配. 不能为标识列指定值(就是最前面的那一序号列),它是自动增长的 列的数据类型为 ...

  3. 2019.3.26 SQL语句(进阶3)

    表的联查 员工表与部门表 员工表:id,姓名,年龄,部门id 部门表:部门id,部门名,部门成立时间,部门领导,部门职责.... 表和表之间的关系 一对一 一对多 多对多 创建联查 创建表 先创建被依 ...

  4. 能写数据后台,需要掌握哪些进阶的sql语句?

    国庆假期花了一些时间,首次尝试并玩转 grafana,这几天继续不断优化和完善,如今看着自己的成果,相当满意.--逐步接近我想要的理想后台啦. 需求是不停歇的.今天我又给自己发掘了一些新需求,比如变量 ...

  5. SQL语句学习手册实例版

    SQL语句学习手册实例版 表操作 例1  对于表的教学管理数据库中的表 STUDENTS ,可以定义如下: CREATE  TABLE  STUDENTS (SNO      NUMERIC (6, ...

  6. 常用Oracle SQL语句(汇总版)

    Oracle数据库常用sql语句 ORACLE 常用的SQL语法和数据对象 一.数据控制语句 (DML) 部分 1.INSERT (往数据表里插入记录的语句) INSERT INTO 表名(字段名1, ...

  7. oracle常用SQL语句(汇总版)

    Oracle数据库常用sql语句 ORACLE 常用的SQL语法和数据对象一.数据控制语句 (DML) 部分 1.INSERT (往数据表里插入记录的语句) INSERT INTO 表名(字段名1, ...

  8. 全国省市级联数据sql语句 mysql版

    全国省市级联数据sql语句 mysql版 --省级 provincial create table provincial ( provincialID int, provincialName ), p ...

  9. 一个项目涉及到的50个Sql语句(整理版)

    /* 标题:一个项目涉及到的50个Sql语句(整理版) 说明:以下五十个语句都按照测试数据进行过测试,最好每次只单独运行一个语句. */ --1.学生表Student(S,Sname,Sage,Sse ...

随机推荐

  1. H5 直播 & App 直播

    H5 直播 & App 直播 polyv 直播 https://github.com/polyv 宝利威 直播 https://www.polyv.net/live/ SDK https:// ...

  2. Techme INC:红光和近红外光疗法有效加速肌肉恢复,美国橄榄球队已采用

    Techme INC创始人兼董事长MADELEINE VAUGHAN表示:在运动结束后,肌肉纤维因为细微损伤造成酸痛情形,即是延迟性肌肉酸痛-DOMS.这类酸痛发生时,需要适度的恢复,避免造成肌肉拉伤 ...

  3. NGK生态商城即将上线官网,推动生态落地应用

    NGK生态商城即将上线官网,以推动生态落地应用.此举意味着NGK生态将跻身区块链顶尖之列,同时,NGK代币.NGK Dapp游戏 "呼叫河马" 以及NGK DeFi项目Baccar ...

  4. NGK公链依靠技术创新推动数字经济产业发展

    数字经济更让人们的生活发生了翻天覆地的变化.数字经济的发展要依靠技术的创新,发展出生态新模式.同时数字经济的发展要利用新技术对传统产业进行全面的的改造升级,释放数字对经济发展的放大.倍增作用.打造数字 ...

  5. 「NGK每日快讯」12.3日NGK公链第30期官方快讯!

  6. HTTPS原理解析

    HTTPS 一些概念 http 概述 HTTP是一个客户端(用户)和服务端(网站)之间请求和应答的标准,通常使用TCP协议.其本身位于TCP/IP协议族的应用层. 特点 - 客户端&服务器 - ...

  7. 自定义Edit 样式 简便写法

    1 <?xml version="1.0" encoding="utf-8"?> 2 <selector xmlns:android=&quo ...

  8. javascript中的内置对象和数据结构

    目录 简介 基础类型 undefined Boolean和Boolean对象 Number和BigInt String Symbol null Object Function Date Array K ...

  9. Oracle数据库在给表添加字段的sql中用comment报错

    原因:不同于mysql,Oracle数据库在添加表字段时不能直接用comment,而是单独写一个sql语句,如下: alter table SYS_USER add SENDMSG_LASTTIME ...

  10. Go的指针

    目录 指针 一.指针的声明 二.指针的默认值(Zero Value) 三.指针的解引用 四.向函数传递指针参数 1.非 数组/切片 指针传参 2.数组/切片 指针传参 五.Go不支持指针运算 指针 指 ...