SQL复合键

时间:2012-12-02 15:46:31

标签: sql compound-key

我正在尝试创建一个表,作为主键使用来自其他表的值。我的讲座说这是一个复合键(主要+外国)但我似乎无法找到如何启动一个有人试图解释这个概念以及如何尝试实现它吗?

1 个答案:

答案 0 :(得分:7)

考虑由学生和课程组成的数据。当您将其存储在DBMS中时,每个学生(或课程)将具有关联的唯一ID,该ID将被称为学生(或课程)的主键

students(id, name, dob)
courses(id, name, credits)

要将学生与他们注册的课程相关联,您将创建一个如下所示的表格。

student_course(student_id, course_id)

要在mysql中实际创建它,您可以编写类似于: -

的内容
CREATE TABLE student_course(student_id INT NOT NULL, 
                            course_id INT NOT NULL, 
                            PRIMARY KEY (student_id, course_id),
                            FOREIGN KEY (student_id) REFERENCES student(id), 
                            FOREIGN_KEY (course_id) REFERENCES course(id))