我正在尝试在 Oracle 中创建一个受多个完整性约束约束的表。该表由一个假设的学生数据库组成。数据库的规则之一是,要被归类为大三学生,他们必须完成 55 到 84 个学分(含)。
我需要创建一个完整性约束来强制执行此规则,但我不完全确定如何去做。我觉得 CHECK 约束在这种情况下会很有用。
到目前为止,我已经...
CONSTRAINT IC4 CHECK (hours >=55 AND hours <= 84),
此代码有效,但不能确定学生记录是否为大三学生。
我的餐桌布置是...
CREATE TABLE Students ( id INTEGER,
name CHAR(10) NOT NULL,
classification CHAR(10) NOT NULL,
hours INTEGER,
gpa NUMBER(3,2) NOT NULL,
mentor INTEGER);
因此,如果我们尝试插入...
INSERT INTO Students VALUES (50, 'Kim', 'junior', 34, 3.5, 40);
...完整性约束将被违反,因为记录试图存储为“初级”,但学生只完成了 34 小时。
我将如何编写一个强制执行这些规则的约束?