数据库系统原理--第2章课堂练习4--答案

题目

设有一个数据库中有三个关系:
学生关系 S(S#,SNAME,AGE,SEX)
课程关系 C(C#,CNAME,TEACHER)
学习关系 SC(S#,C#,GRADE)
在这里插入图片描述

1、下面用关系代数表达式表达各个查询语句:

  1. 检索年龄大于 20 岁的男学生的学号、姓名。
    Π S#,SNAME(σ AGE>20^SEX=‘男’(S))

  2. 检索学习课程号为C2 的学生学号与成绩。
    Π S#,GRADE(σ C#=‘C2’(SC))

  3. 检索学习课程号为C2 的学生学号与姓名。
    Π S#,SNAME(σ C#=‘C2’(SC∞S))

  4. 检索选修课程名为MATHS 的学生学号与姓名。
    Π S#,SNAME(σ CNAME(‘MATHS’(C∞SC∞S)

  5. 检索王华老师所授课程的课程号、课程名
    Π C#,CNAME(σ TEACHER=‘王华’( C))

  6. 检索选修课程号为C2 或C4 的学生学号。
    Π S#(σ C#='C2∨C#=‘C4’(SC))

  7. 检索至少选修课程号为 C2 和C4 的学生学号。
    Π S#,C#(SC)÷Π S#(σ C#=‘C2’^C#=‘C4’(SC))

  8. 检索至少选修两门课程的学生学号。
    Π SNAME,AGE(S) - Π SNAME,AGE(σ C#=‘C2’(SC∞S))

  9. 检索不学C2 课的学生姓名与年龄。
    ΠS#,C#((Π S#,C#(SC)÷Π C#( σ C#=‘C2’(SC)))∞S)

  10. 检索全部学生都选修的课程的课程号、课程名。
    Π C#,CNAME (Π S#,C#(SC)÷Π S#(S) ∞C)

  11. 检索学习全部课程的学生姓名。
    Π SNAME(S∞(Π S#,C#(SC)÷Π C#( C))

11题思路:
在这里插入图片描述

2、下面用SQL语言表达各个查询语句:

  1. 检索选修课程号为C2 或C4 的学生学号。
SELECT DISTINCT S#
FROM SC
WHERE C#='C2' OR C#='C4'

查询结果
在这里插入图片描述
2. 检索至少选修课程号为 C2 和C4 的学生学号。

SELECT DISTINCT S#
FROM SC
WHERE C#='C2'
AND S# IN (SELECT S# FROM SC WHERE C#='C4')

查询结果
在这里插入图片描述
3. 检索至少选修两门课程的学生学号。

SELECT S#
FROM SC
GROUP BY S#
HAVING COUNT(*)>1

查询结果
在这里插入图片描述

附上代码

(包括创建数据库、3张表以及上面3个问题的sql查询语言)

--创建数据库
CREATE DATABASE AAA
--使用数据库
USE AAA
--创建S表
CREATE TABLE S(
S# CHAR(10) PRIMARY KEY,
SNAME CHAR(50),
AGE CHAR(20),
SEX CHAR(20))
--添加数据到S表
INSERT INTO S(S#,SNAME,AGE,SEX)
VALUES('1','李强',19,'男'),
('2','刘丽',22,'女'),
('3','张友',22,'男')
--检验
SELECT * FROM S

--创建C表
CREATE TABLE C(
C# CHAR(10) PRIMARY KEY,
CNAME CHAR(50) ,
TEACHER CHAR(20))
--添加数据到P表
INSERT INTO C(C#,CNAME,TEACHER)
VALUES('C1','C语言','王华'),
('C2','数据课原理','程军'),
('C4','MATHS','程军')
--检验
SELECT * FROM C

--创建SC表
CREATE TABLE SC(
S# CHAR(10),
C# CHAR(50),
GRADE CHAR(20))
--添加数据到J表
INSERT INTO SC(S#,C#,GRADE)
VALUES('1','C1','83'),
('2','C1','85'),
('5','C1','92'),
('2','C2','90'),
('5','C2','84'),
('5','C4','80')
--检验
SELECT * FROM SC

--1.检索选修课程号为C2 或C4 的学生学号。
SELECT DISTINCT S#
FROM SC
WHERE C#='C2' OR C#='C4'

--2.检索至少选修课程号为 C2 和C4 的学生学号。
SELECT DISTINCT S#
FROM SC
WHERE C#='C2'
AND S# IN (SELECT S# FROM SC WHERE C#='C4')

--3.检索至少选修两门课程的学生学号。
SELECT S#
FROM SC
GROUP BY S#
HAVING COUNT(*)>1


  • 6
    点赞
  • 91
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

三桥君

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值