一、实验目的
本次实验主要目的包括:
- 熟练掌握使用 SQL 语句实现更新操作的方法,能够对数据库中的数据进行准确修改。
- 深刻认识完整性约束对数据库的重要性,理解其在维护数据准确性、一致性和可靠性方面的关键作用。
- 精通在 MySQL 中对完整性约束创建和修改的方法,以便根据实际业务需求灵活设置数据库约束条件。
二、各类数据库操作 SQL 语句及分析
(一)插入学院信息
- 问题描述:在学院表中增加一个新的学院,外国语学院,学院编号为 15,院长暂时不设置。
- 我的答案 SQL 语句:无
- 正确答案 SQL 语句:
收起
sql
-- MySQL 语句(2 分)
INSERT INTO Department(Dno,Dname)
VALUES ('15','外国语学院');
(二)更新学生课程成绩
- 问题描述:学号为 2014112103 的学生的数据结构课程的补考成绩为 63 分,请用补考成绩更新原有的考试成绩。
- 我的答案 SQL 语句:无
- 正确答案 SQL 语句:
收起
sql
-- MySQL 语句(2 分)
UPDATE Reports
SET Grade=63
WHERE Sno='2014112103'
AND Cno=
(SELECT Cno FROM Courses
WHERE Cname='数据结构'
);
(三)为表添加列并设置属性
- 问题描述:为表 Tutors 增加新列 Tutid,将该列设置为第一列,并将 Tutid 列设置为自动增长的整数列,同时设置该列为主键。
- 我的答案 SQL 语句:无
- 正确答案 SQL 语句:
收起
sql
-- MySQL 语句(2 分)
ALTER TABLE tutors
ADD Tutid INT AUTO_INCREMENT PRIMARY KEY FIRST;
(四)多表更新插入数据
- 问题描述:2018 学年第 1 学期,为 20171151 班的所有学生开设了计算机网络课程,并由 “许永军” 教授进行授课。
- 我的答案 SQL 语句:无
- 正确答案 SQL 语句:
收起
sql
-- MySQL 语句(4 分)
-- ① 先插入授课信息
INSERT INTO Tutors
(Tno,Cno,Tacademicyear,Tterm,Sclass)
VALUES
((SELECT Tno FROM Teachers WHERE Tname='许永军'),
(SELECT Cno FROM Courses WHERE Cname='计算机网络'),
2018,1,'20171151');
-- ② 再插入选课信息
INSERT INTO Reports
(Sno,Cno,Racademicyear,Rterm)
(SELECT Sno,Cno,2018,1
FROM Students, Courses
WHERE Sclass='20171151' AND Cname='计算机网络');
(五)更新授课教师信息
- 问题描述:李桂清教授光荣退休了,需要将他在 2018 学年第 2 学期给 20161121 班的学生所上的数字图像制作课程将改由李力授课。
- 我的答案 SQL 语句:无
- 正确答案 SQL 语句:
收起
sql
-- MySQL 语句(3 分)
UPDATE Tutors
SET Tno=(SELECT Tno FROM Teachers WHERE Tname='李力')
WHERE Tno=(SELECT Tno FROM Teachers WHERE Tname='李桂清')
AND Cno=(SELECT Cno FROM Courses WHERE Cname='数字图像制作')
AND Sclass ='20161121' AND Tacademicyear=2018 AND Tterm=2;
(六)删除教师信息及相关问题
- 问题描述:李桂清教授光荣退休了,需要将他的信息从教师表中删除,并回答相关问题。
- 我的答案 SQL 语句:无
- 正确答案 SQL 语句:
收起
sql
-- MySQL 语句(2 分)
DELETE FROM Teachers
WHERE Tname='李桂清';
-
回答问题:
- ① 删除失败
- ② 因为授课表中有李桂清教授的授课信息,违反参照完整性约束
(七)解决教师退休信息处理问题
- 问题描述:李桂清教授虽然退休了,但是很明显不能直接将他从教师信息表中删除,因为在授课表中还有他往年的授课信息,那么这个问题该如何解决呢?既能分辨教师是否退休,又不会影响到他之前的授课信息。
- 我的答案 SQL 语句:无
-
正确答案:
- 参考问题:(3 分)(注意,此处仅为参考答案,可根据学生答题分析可行性予以评分)
- 可以在教师表中增加一个新的属性列,标识是否在岗 TInWork,数据类型设置为 VARCHAR (4),默认可设置为 “在岗”,若教师退休,可将该属性列的值修改为 “退休”。还可以标识为其他状态,如 “进修”、“读博”、“病假” 等。
(八)删除学生信息及相关问题
- 问题描述:学号为 2017120202 的学生因病退学了,请从学生表中将他的信息删除,并回答相关问题。
- 我的答案 SQL 语句:无
- 正确答案 SQL 语句:
收起
sql
-- MySQL 语句(2 分)
DELETE FROM Students
WHERE Sno='2017120202';
-
回答问题:
- ① 删除失败
- ② 因为选课表中有该位学生的选课信息,违反参照完整性(外键)约束
(九)设置级联删除后删除学生信息
- 问题描述:将选课表中对 Sno 的外键声明重新设置可为级联删除;再从学生表中将学号 2017120202 的学生信息删除,并回答相关问题。
- 我的答案 SQL 语句:无
- 正确答案 SQL 语句:
收起
sql
-- MySQL 语句(6 分)
① 重新设置外键
ALTER TABLE reports
DROP CONSTRAINT FK_Sno;
ALTER TABLE reports
ADD CONSTRAINT FK_Sno FOREIGN KEY(Sno)
REFERENCES students(Sno)
ON DELETE CASCADE;
② 删除学生信息
DELETE FROM Students
WHERE Sno='2017120202';
-
回答问题:
- ① 删除成功
- ② 因为设置了级联删除,所以当删除学生表中的学生信息时,系统会自动将选课表中该位学生的选课信息一起删除
(十)更新专业编号及相关问题
- 问题描述:由于人才培养方案的变更,数学与统计学院的数据科学与大数据技术(非师范)专业的编号将变更为编号 1203,请直接将专业表中的专业编号 1202 更改为 1203 的信息,并回答相关问题。
- 我的答案 SQL 语句:无
- 正确答案 SQL 语句:
收起
sql
-- MySQL 语句(2 分)
UPDATE major
SET Mno='1203'
WHERE Mno='1202';
-
回答问题:
- ① 更新失败
- ② 因为学生表中有与该专业相关联的学生信息,违反参照完整性(外键)约束
(十一)设置级联更新后更新专业编号
- 问题描述:将学生表中对 Mno 的外键声明重新设置可为级联更新;再重新更新专业表中数据科学与大数据技术(非师范)专业的专业编号,并回答相关问题。
- 我的答案 SQL 语句:无
- 正确答案 SQL 语句:
收起
sql
-- MySQL 语句(6 分)
① 重新设置外键
ALTER TABLE students
DROP CONSTRAINT FK_Mno;
ALTER TABLE students
ADD CONSTRAINT FK_Mno FOREIGN KEY(Mno)
REFERENCES major(Mno)
ON UPDATE CASCADE;
② 更新专业信息
UPDATE major
SET Mno='1203'
WHERE Mname='数据科学与大数据技术(非师范)';
-
回答问题:
- ① 更新成功
- ② 因为设置了级联更新,所以当更新专业表中的专业编号时,系统会自动将学生表中该专业编号更新为新的专业编号
(十二)批量更新学院院长信息
- 问题描述:分别任命李力、张兰和张雪为本学院的院长,要求使用一条更新语句完成次操作。
- 我的答案 SQL 语句:无
- 正确答案 SQL 语句:
收起
sql
-- MySQL 语句(3 分)
UPDATE Department D,
( SELECT Dno, Tno
FROM Teachers
WHERE Tname IN ('李力', '张兰', '张雪')
) DH
SET Dheader=DH.Tno
WHERE D.Dno=DH.Dno;
(十三)创建教师工作量统计表
- 问题描述:创建一个教师工作量统计表 TeaQuantity,其中包含统计编号 Qid、教师编号 Tno、学年 Tacademicyear 和工作量 Tquantity,其中 Tno 和 Tacademicyear 的数据类型与 Tutors 表中的设置相同,Qid 的数据类型定义为 Binary (16),默认输入 UNIQUEINDETIFIER (UUID) 的二进制数,且设置为该表的主键,Tquantity 的数据类型设置为整数,并且在属性列 Tno 和 Tacademicyear 上设置唯一性约束,即约束该表中每个教师编号,每个学年只统计一个工作量。
- 我的答案 SQL 语句:无
- 正确答案 SQL 语句:
收起
sql
-- MySQL 语句(3 分)
CREATE TABLE TeaQuantity
(Qid Binary(16) PRIMARY KEY DEFAULT (UUID_TO_BIN(UUID())),
Tno CHAR(4),
Tacademicyear YEAR,
Tquantity INT,
CONSTRAINT UK_Tno UNIQUE KEY(Tno,Tacademicyear)
);
(十四)统计教师授课工作量并插入表
- 问题描述:对所有教师的授课工作量按学年进行统计,即统计出每个学年该位教师所上课程的总课时量,并将统计结果添加到 TeaQuantity 表中。
- 我的答案 SQL 语句:无
- 正确答案 SQL 语句:
收起
sql
-- MySQL 语句(3 分)
INSERT INTO TeaQuantity(Tno, Tacademicyear, Tquantity)
(SELECT Tno,Tacademicyear,SUM(Chours)
FROM Tutors Tut,Courses C
WHERE Tut.Cno=C.Cno
GROUP BY Tno,Tacademicyear);
(十五)多步骤操作及统计插入
- 问题描述:① 2019 学年第 1 学期,为 20171202 班的所有学生开设了数据库系统原理,并由 “王平” 老师进行授课;② 重新对 “王平” 老师的授课工作量按学年进行统计,再次将统计结果添加到 TeaQuantity 表中。
- 我的答案 SQL 语句:无
- 正确答案 SQL 语句:
收起
sql
-- MySQL 语句(6 分)
① 添加授课记录
INSERT INTO Tutors(Tno,Cno,Tacademicyear,Tterm,Sclass)
VALUES
((SELECT Tno FROM Teachers WHERE Tname='王平'),
(SELECT Cno FROM Courses WHERE Cname='数据库系统原理'),
2019,1,'20171202');
-- ② 再插入选课信息
INSERT INTO Reports(Sno,Cno,Racademicyear,Rterm)
(SELECT Sno,Cno,2019,1
FROM Students, Courses
WHERE Sclass='20171202' AND Cname='数据库系统原理');
③ 插入授课工作量统计表
INSERT INTO TeaQuantity(Tno,Tacademicyear,Tquantity)
(SELECT Tut.Tno,Tacademicyear,SUM(Chours)
FROM Tutors Tut,Courses C, Teachers T
WHERE Tut.Cno=C.Cno AND T.Tno=Tut.Tno AND Tname='王平'
GROUP BY Tno,Tacademicyear);
(十六)更新教师授课工作量统计
- 问题描述:重新对 “王平” 老师的授课工作量按学年进行统计,并将统计结果更新到 TeaQuantity 表中。
- 我的答案 SQL 语句:无
- 正确答案 SQL 语句:
收起
sql
-- MySQL 语句(3 分)
UPDATE TeaQuantity,
(SELECT Tut.Tno,Tacademicyear,SUM(Chours) SumofQuantity
FROM Tutors Tut,Courses C, Teachers T
WHERE Tut.Cno=C.Cno AND T.Tno=Tut.Tno AND Tname='王平'
GROUP BY Tno,Tacademicyear) TQ
SET TeaQuantity.Tquantity= TQ.SumofQuantity
WHERE TeaQuantity.Tno=TQ.Tno AND TeaQuantity.Tacademicyeart=TQ.Tacademicyear;
(十七)添加学生表 CHECK 约束及验证
- 问题描述:在学生表中增加 CHECK 约束:Sno 的长度必须为 10 个字符长度;分别向学生表中添加一条正确的学生信息和一条错误的学生信息,验证 CHECK 约束是否能正确执行。
- 我的答案 SQL 语句:无
- 正确答案 SQL 语句:
收起
sql
-- MySQL 语句(6 分)
① CHECK 约束
ALTER TABLE Students
ADD CONSTRAINT CHK_LenSno CHECK (CHAR_LENGTH(Sno)=10);
② 错误信息验证
INSERT INTO Students(Sno,Sname)
VALUES ('202311','李四');
③ 正确信息验证
INSERT INTO Students(Sno,Sname)
VALUES ('2023115101','李四');
(十八)添加教师表 CHECK 约束
- 问题描述:在教师表中增加 CHECK 约束:若教师的职称是教授,则其工资 Tsal 要在 3500 元以上;若教师的职称是副教授,则其工资要在 2600 元到 3500 元之间;若教师的职称是讲师,则其工资要在 1600 元到 2600 元之间;若教师的职称是助教,则其工资要在 800 元到 1600 元之间。
- 我的答案 SQL 语句:无
- 正确答案 SQL 语句:
收起
sql
-- MySQL 语句(4 分)
ALTER TABLE Teachers
ADD CONSTRAINT CHK_Tprof_Tsal
CHECK (Tprof = '教授' and Tsal > 3500
OR Tprof = '副教授' and Tsal BETWEEN 2600 AND 3500
OR Tprof = '讲师' and Tsal BETWEEN 1600 AND 2600
OR Tprof = '助教' and Tsal BETWEEN 800 AND 1600);
(十九)更新教师信息及约束验证
- 问题描述:张兰老师因评上教授,需将其职称 (Tprof) 由副教授改为教授,并将工资 (Tsal) 改为 3300,岗位津贴 (Tcomm) 改为 2400,并回答相关问题。
- 我的答案 SQL 语句:无
- 正确答案 SQL 语句:
收起
sql
-- MySQL 语句(2 分)
UPDATE Teachers
SET Tprof='教授', Tsal=3300, Tcomm=2400
WHERE Tname='张兰';
-
回答问题:
- ① 更新失败
- ② 因为输入的工资不满足 CHECK 约束
(二十)更新教师信息成功案例
- 问题描述:许红霞老师评上了副教授,需将其职称 (Tprof) 由讲师改为副教授,并将工资 (Tsal) 改为 2700,岗位津贴 (Tcomm) 改为 2000,并回答相关问题。
- 我的答案 SQL 语句:无
- 正确答案 SQL 语句:
收起
sql
-- MySQL 语句(2 分)
UPDATE Teachers
SET Tprof='副教授', Tsal=2700, Tcomm=2000
WHERE Tname='许红霞';
-
回答问题:
- ① 更新成功
- ② SELECT * FROM Teachers WHERE Tname=' 许红霞 ';
通过本次实验,我们深入学习了 SQL 数据库的更新操作以及完整性约束的设置与应用。在实际数据库管理中,正确运用这些知识可以确保数据的准确性、一致性和完整性,避免因数据错误或不一致而导致的各种问题。无论是数据的插入、更新还是删除操作,都需要充分考虑完整性约束的影响,以构建稳健可靠的数据库系统。同时,根据业务需求合理设置约束条件,能够有效规范数据的录入和修改,提高数据库的质量和可用性。