在TB_Student中加一字段TotalGrade,创建一个触发器,当向TB_Grade表插入记录后,如果成绩非空则在该学生的TotalGrade中自动加上该门课程的得分。
时间: 2024-03-24 17:41:54 浏览: 20
好的,以下是对应的触发器的 SQL 语句:
```sql
-- 创建触发器
CREATE TRIGGER add_grade_trigger
AFTER INSERT ON TB_Grade
FOR EACH ROW
BEGIN
IF NEW.Grade IS NOT NULL THEN
UPDATE TB_Student SET TotalGrade = TotalGrade + NEW.Grade WHERE StudentID = NEW.StudentID;
END IF;
END;
```
触发器中使用了 `IF` 语句判断插入的新记录的成绩是否为空,如果不为空,则使用 `UPDATE` 语句对 `TB_Student` 表进行更新,将对应学生的 `TotalGrade` 字段加上该门课程的得分。其中,`NEW.StudentID` 表示插入的新记录的学生 ID,即将要更新的学生的 ID。需要注意的是,这个触发器只在插入成绩时触发,对于更新或删除操作不会触发。
相关问题
TB_Dept(DeptID,DeptName,DeptSetDate) TB_Teacher(TeacherID,TeacherName,DeptID,Sex,Birthday) TB_Class(ClassID,ClassName,DeptID,TeacherID) TB_Student(StuID,StuName,DeptID,ClassID,Sex,Birthday) TB_Course(CourseID,CourseName,DeptID,CourseGrade,LessonTime, CourseOutline) TB_CourseClass(CourseClassID,CourseID,TeacherID,CommonPart,MiddlePart,LastPart) TB_SelectCourse(StuID,CourseClassID,SelectDate) TB_Grade(StuID,ClassID,CourseClassID,CourseID,CommonScore,MiddleScore,LastScore,TotalScore,RetestScore) 根据上面的表,1、创建一个AFTER型语句级触发器,当对学生表执行插入操作时,统计插入操作后学生的最小年龄并输出;当对学生表执行更新操作时,统计更新后学生的平均年龄并输出;当对学生表执行删除操作时,统计删除后学生的总人数并输出(参考后面例题)。要验证 2、用AFTER触发器实现选课人数自减功能,实现当在表TB_SelectCourse上删除选课记录时,自动将对应课程班TB_CourseClass表中的已选学生人数(SelectedNumber)减1。要验证 3、在TB_Class表中加一字段ClassNumber以记录班级人数,设计一触发器,要求在TB_Student中加入学生时,自动将对应班级表中的ClassNumber加1。 4、在TB_Student中加一字段TotalGrade,创建一个触发器,当向TB_Grade表插入记录后,如果成绩非空则在该学生的TotalGrade中自动加上该门课程的得分。
1、触发器代码如下:
CREATE TRIGGER tr_stu_insert_update_delete
AFTER INSERT OR UPDATE OR DELETE ON TB_Student
BEGIN
IF (SELECT COUNT(*) FROM TB_Student) > 0 THEN -- 防止除零错误
CASE
WHEN INSERTING THEN -- 插入操作
SELECT MIN(strftime('%Y', 'now') - strftime('%Y', Birthday)) AS "插入后最小年龄" FROM TB_Student;
WHEN UPDATING THEN -- 更新操作
SELECT AVG(strftime('%Y', 'now') - strftime('%Y', Birthday)) AS "更新后平均年龄" FROM TB_Student;
WHEN DELETING THEN -- 删除操作
SELECT COUNT(*) AS "删除后学生总人数" FROM TB_Student;
END CASE;
END IF;
END;
2、触发器代码如下:
CREATE TRIGGER tr_select_course_delete
AFTER DELETE ON TB_SelectCourse
BEGIN
UPDATE TB_CourseClass SET SelectedNumber = SelectedNumber - 1 WHERE CourseClassID = OLD.CourseClassID;
END;
3、触发器代码如下:
CREATE TRIGGER tr_stu_insert_classnumber
AFTER INSERT ON TB_Student
BEGIN
UPDATE TB_Class SET ClassNumber = ClassNumber + 1 WHERE ClassID = NEW.ClassID;
END;
4、触发器代码如下:
CREATE TRIGGER tr_grade_insert_totalgrade
AFTER INSERT ON TB_Grade
BEGIN
UPDATE TB_Student SET TotalGrade = TotalGrade + NEW.TotalScore WHERE StuID = NEW.StuID;
END;
在TB_Class表中加一字段ClassNumber以记录TB_Student表中字段ClassID=TB_Class表中的字段ClassID的数量
可以使用以下 SQL 语句来实现:
```
ALTER TABLE TB_Class ADD ClassNumber INT DEFAULT 0;
UPDATE TB_Class
SET ClassNumber = (SELECT COUNT(*) FROM TB_Student WHERE TB_Student.ClassID = TB_Class.ClassID);
```
首先,使用 `ALTER TABLE` 语句来向 `TB_Class` 表中添加一个名为 `ClassNumber` 的整数类型字段,初始值为 0。
接着,使用 `UPDATE` 语句来更新 `TB_Class` 表中的 `ClassNumber` 字段。对于每一条记录,使用子查询来统计 `TB_Student` 表中 `ClassID` 等于当前记录 `ClassID` 的数量,并将结果赋值给 `ClassNumber` 字段。
这样,就能够在 `TB_Class` 表中记录与之对应的学生数量了。