使用SQL进行集合查询和数据维护

简介: 使用SQL进行集合查询和数据维护

1.分别查询“计科系学生”和“所有男生”的并集,交集和差集。(15分)

–并集

SELECT *
FROM Student
WHERE Sdept='计算机系'
UNION
SELECT *
FROM Student
WHERE Sex='男'
–交集
SELECT *
FROM Student
WHERE Sdept='计算机系'
INTERSECT
SELECT *
FROM Student
WHERE Sex='男'
–差集
SELECT *
FROM Student
WHERE Sdept='计算机系'
EXCEPT
SELECT *
FROM Student
WHERE Sex='男'

2.查询选修了“10001”号课程或选修了“10005”课程的学生学号。(5分)

SELECT Sno
FROM SC
WHERE Cno='10001'
UNION
SELECT Sno
FROM SC
WHERE Cno='10005'

3.查询同时选修了“10001”和“10005” 号课程的学生学号。(5分)

SELECT Sno
FROM SC
WHERE Cno='10001'
INTERSECT
SELECT Sno
FROM SC
WHERE Cno='10005'

4.查询选修了“10001”号课程,但没选“10005” 号课程的学生学号。(5分)

SELECT Sno
FROM SC
WHERE Cno='10001'
EXCEPT
SELECT Sno
FROM SC
WHERE Cno='10005'

Ø *维护操作*

5.在学生表中插入一条新的学生记录,数据可自拟。(注意,插入的数据需满足完整性约束)(5分)

INSERT INTO Student
VALUES('20030101','王芳','女',19 ,'计算机系')

6.插入一条选课记录,学号:10010118,课程号:20008,能否插入成功?为什么?(5分)

INSERT INTO SC(Sno,Cno)
VALUES('10010118','20008')
不能,错误提示:NSERT 语句与 FOREIGN KEY 约束"FK_Sno"冲突。Cno是外键,参照Course中Cno的数值,Course中不存在课程号为“20008”的课程记录。

7.查询每个系及其人数,将查询结果插入到新表Sdept_Count中(10分)

--创建表
CREATE TABLE Sdept_Count(
Sdept varchar(50),
SNum int
)
--插入操作
INSERT INTO Sdept_Count(Sdept,SNum)
SELECT Sdept,COUNT(Sno)
FROM Student
GROUP BY Sdept

8.将学生“徐庆”的所在系修改为“计算机系”(5分)

UPDATE Student
SET Sdept='计算机系'
WHERE Sname='徐庆'

9.将所有课程的学分Credit提高1分。(5分)

UPDATE Course
SET Credit=Credit+1

10.将“徐庆”同学的学号修改为“19010101”,能否修改成功?为什么?(5分)

UPDATE Student
SET Sno='19010101'
WHERE Sname='徐庆'
不能修改成功,因为该生在SC表中存在选课记录。

11.将选修了“计算机基础”这门课的学生成绩提高0.2(10分)

UPDATE SC
SET Score=Score*1.2
WHERE Sno IN(SELECT SNO
FROM SC
WHERE Cno=(SELECT Cno
FROM Course
WHERE Cname='计算机基础'))

12.删除学号为“10010118”的学生记录。能否成功删除?不能删除的原因?如何解决?(10分)

不能删除,原因是SC表中还存在外键的约束,即“10010118”的选课记录。如果要成功删除学生“10010118”,需要先删除其所有选课记录。

DELETE FROM SC
WHERE Sno='10010118'
``
DELETE FROM Student
WHERE Sno='10010118'

13.删除“计算机基础”这门课不及格的选课记录(10分)

DELETE FROM SC
WHERE Score<60 AND Cno=
(SELECT Cno
FROM Course
WHERE Cname='计算机基础')

14.把选课表SC清空。(5分)

DELETE FROM SC
目录
相关文章
|
2天前
|
SQL Java 数据库连接
如何使用`DriverManager.getConnection()`连接数据库,并利用`PreparedStatement`执行参数化查询,有效防止SQL注入。
【10月更文挑战第6天】在代码与逻辑交织的世界中,我从一名数据库新手出发,通过不断探索与实践,最终成为熟练掌握JDBC的开发者。这段旅程充满挑战与惊喜,从建立数据库连接到执行SQL语句,再到理解事务管理和批处理等高级功能,每一步都让我对JDBC有了更深的认识。示例代码展示了如何使用`DriverManager.getConnection()`连接数据库,并利用`PreparedStatement`执行参数化查询,有效防止SQL注入。
14 5
|
1天前
|
SQL 存储 关系型数据库
添加数据到数据库的SQL语句详解与实践技巧
在数据库管理中,添加数据是一个基本操作,它涉及到向表中插入新的记录
|
2天前
|
SQL 数据挖掘 数据库
SQL查询每秒的数据:技巧、方法与性能优化
id="">SQL查询功能详解 SQL(Structured Query Language,结构化查询语言)是一种专门用于与数据库进行沟通和操作的语言
|
2天前
|
SQL 移动开发 大数据
SQL语句查询连续六天满足条件的记录
在数据库管理和数据分析中,我们经常需要查询符合特定时间范围内连续几天的记录
|
4天前
|
SQL 监控 数据处理
SQL数据库数据修改操作详解
数据库是现代信息系统的重要组成部分,其中SQL(StructuredQueryLanguage)是管理和处理数据库的重要工具之一。在日常的业务运营过程中,数据的准确性和及时性对企业来说至关重要,这就需要掌握如何在数据库中正确地进行数据修改操作。本文将详细介绍在SQL数据库中如何修改数据,帮助读者更好
39 4
|
5天前
|
SQL 数据挖掘 关系型数据库
SQL查询次数大于1的记录:高效技巧与方法
在数据库管理中,经常需要统计某些操作的次数,特别是当需要找出哪些记录或值出现的次数超过一定阈值(如大于1次)时
|
4天前
|
SQL 存储 安全
SQL查询数据库:基础概念与操作指南
在数字化时代,数据库已成为信息管理的重要工具之一。作为管理和操作数据库的核心语言,SQL(结构化查询语言)已成为数据管理和查询的关键技能。本文将全面介绍SQL查询数据库的基本概念、语句和操作指南,以帮助初学者快速上手,同时为进阶用户提供有价值的参考。一、数据库与SQL简介数据库是一种存储、管理和检索
20 3
|
5天前
|
SQL 数据库
SQL查询中排除空值列的技巧与方法
在数据库查询中,经常需要处理包含空值(NULL)的数据列
|
5天前
|
SQL Oracle 关系型数据库
SQL查询默认表空间的技巧与方法
在数据库管理中,表空间是存储数据库对象(如表、索引等)的逻辑空间单元
|
22小时前
|
SQL 监控 关系型数据库
使用SQL语句查询操作耗时的技巧与方法
在数据库管理和优化过程中,了解SQL查询操作的耗时是至关重要的