设有3个关系: S(S#,SNAME,SEX,AGE) SC(S#,C#,GRADE) C(C#,CNAME,TEACHER) 试用关系代数表达式表示下列查询语句:(1)~(8)小题
时间: 2024-03-18 22:34:37 浏览: 52
(1) 查询所有学生的姓名和年龄:
π SNAME, AGE (S)
(2) 查询选了课程C1并且成绩不低于80分的学生的学号和姓名:
π S# SNAME (σ C#='C1' ∧ GRADE>=80 (SC ⨝ S))
(3) 查询选了课程C1或C2并且成绩不低于80分的学生的学号和姓名:
π S# SNAME (σ (C#='C1' ∨ C#='C2') ∧ GRADE>=80 (SC ⨝ S))
(4) 查询没有选课程的学生的学号和姓名:
π S# SNAME (S - π S# (SC ⨝ S))
(5) 查询至少选了两门课程的学生的学号和姓名:
π S# SNAME (σ COUNT(C#)≥2 (SC ⨝ S) ⨝π S# (SC))
(6) 查询选修了张老师教授的课程的学生的学号和姓名:
π S# SNAME (SC ⨝σ TEACHER='张' (C))
(7) 查询选修了至少一门课程的女生的学号和姓名:
π S# SNAME (σ SEX='女' ∧ S# IN (π S# (SC ⨝ S)))
(8) 查询选修了全部课程的学生的学号和姓名:
π S# SNAME (σ COUNT(C#)=(SELECT COUNT(*) FROM C) (SC ⨝ S))
相关问题
设教学数据库的模式如下: S(S#,SNAME,AGE,SEX,SDEPT) SC(S#,C#,GRADE) C(C#,CNAME,TEACHER) 1) 试用定义下列完整性约束: (1)在关系 S 中插入学生年龄值应在 16~25 岁之间(3 分) (2)在关系 SC 中插入元组时,其 S#值和 C#值必须分别在 S 和 C 中出现。(3 分)
(1) 在关系 S 中插入学生年龄值应在 16~25 岁之间,可以使用 CHECK 约束来定义。具体定义方式如下:
```sql
ALTER TABLE S ADD CONSTRAINT age_check CHECK (AGE BETWEEN 16 AND 25);
```
这条语句将对关系 S 中的 AGE 属性添加一个 CHECK 约束,要求 AGE 的取值必须在 16~25 岁之间。
(2) 在关系 SC 中插入元组时,其 S#值和 C#值必须分别在 S 和 C 中出现,可以使用 FOREIGN KEY 约束来定义。具体定义方式如下:
```sql
ALTER TABLE SC ADD CONSTRAINT sc_fk_s FOREIGN KEY (S#) REFERENCES S(S#);
ALTER TABLE SC ADD CONSTRAINT sc_fk_c FOREIGN KEY (C#) REFERENCES C(C#);
```
这两条语句将对关系 SC 中的 S# 和 C# 属性分别添加 FOREIGN KEY 约束,要求它们的取值必须分别在关系 S 和 C 中出现。这样可以保证在插入 SC 的元组时,S#和C#的取值都是合法的,符合参照完整性约束。
学生关系 S(S#,SNAME,AGE,SEX) 选课关系 SC(S#,C#,GRADE) 课程关系 C(C#,CNAME,TEACHER) 查询学习课程号为C2的学生学号与成绩
可以使用如下 SQL 语句查询学习课程号为 C2 的学生学号与成绩:
```sql
SELECT S.S#, SC.GRADE
FROM S, SC
WHERE S.S# = SC.S# AND SC.C# = 'C2';
```
该语句通过内连接(使用 WHERE 子句)将学生关系 S 和选课关系 SC 进行关联,并筛选出选修课程号为 C2 的记录,最后选择学生学号和成绩两个字段进行查询。