1

我有一个代表学校的数据库,其中包含课程、学生和入学等表。它们具有以下架构:

CREATE TABLE Students(
id INT CHECK(id > 100000),
lName CHAR(20),
fName CHAR(10),
gender CHAR(1) CHECK(gender IN('F','M')),
dob DATE,
address CHAR(100),
phone INT CHECK(phone > 1000000000),
grade CHAR(1) CHECK(grade IN('K','1','2','3','4','5')),
PRIMARY KEY(id));

CREATE TABLE Courses(
id INT CHECK(id > 1000),
name CHAR(40),
grade CHAR(1) CHECK(grade IN('K','1','2','3','4','5')),
PRIMARY KEY(id)
);

CREATE TABLE Enrollment(
studentID INT REFERENCES Students(id),
courseID INT REFERENCES Courses(id),
semester CHAR(6) CHECK(semester IN('Fall','Spring')),
year INT,
letterGrade CHAR(1) CHECK(letterGrade IN('A','B','C','D','E')),
PRIMARY KEY(studentID,courseID,semester,year));

我想为注册表创建一个触发器,该触发器将在插入元组之前检查具有给定 studentID 的学生的年级水平和具有 courseID 的课程的年级水平是否相等。我已经为此工作了一段时间,但似乎无法让它发挥作用。谁能指出我正确的方向?这就是我想出的:

CREATE TRIGGER appropriateLevel
   ...> BEFORE INSERT ON Enrollment
   ...> FOR EACH ROW
   ...> BEGIN
   ...> SELECT RAISE(ABORT,'The student's grade does not match the grade level of the course.')
   ...> WHERE EXISTS(SELECT * FROM Students, Courses WHERE ((Students.grade = Courses.grade) AND (Students.id = NEW.studentID) AND (Courses.id = NEW.courseID)));
   ...> END;

谢谢!

4

1 回答 1

1

当成绩匹配时,您的触发器会中止。

无论如何,您不需要使用EXISTS,因为您只想比较每个父表中的一个特定值:

CREATE TRIGGER appropriateLevel
BEFORE INSERT ON Enrollment
FOR EACH ROW
BEGIN
    SELECT RAISE(ABORT, 'The student''s grade does not match the course''s grade level.')
    WHERE (SELECT grade FROM Students WHERE id = NEW.studentID) <>
          (SELECT grade FROM Courses  WHERE id = NEW.courseID);
END;
于 2013-04-14T11:10:42.467 回答