微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

允许同一年不同科目,但不允许同一科目不同年份

如何解决允许同一年不同科目,但不允许同一科目不同年份

我正在创建一个 sql 表来记录学生所学科目的信息。我有一个限制,即允许学生在同一年修读多个科目,但不允许在不同年份修读相同的科目。例如,2021年可以选微积分I、微积分II、微积分III,2019、2020、2021年不能选微积分I。

如何在我的 sql 表中放置这样的约束?

我在想:

CREATE TABLE STUDENT(
    STUDENT_ID NUMBER PRIMARY KEY,COURSES VARCHAR (1000) NOT NULL,YEAR NUMBER NOT NULL,UNIQUE(COURSES,YEAR)
);

但是我意识到unique只是阻止了(courses,year)的相同元组出现,但是如果年份改变了,它仍然会被允许,这不是我想要的。

由于我这周只学习了如何编写 sql 代码,是否还有其他关键字可以用来解决我的问题?非常感谢。

解决方法

我认为您想要对 student_id/subject 的唯一约束:

alter table student add constraint unq_student_id_course_year
    unique (student_id,courses);

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。