MySQL是一種關(guān)系型數(shù)據(jù)庫管理系統(tǒng),其設(shè)計(jì)理念是基于關(guān)系模型進(jìn)行數(shù)據(jù)組織和處理。在MySQL中,表(table)是其中最基礎(chǔ)的概念,而所屬關(guān)系(relationship)就是指表之間的關(guān)系。
在MySQL中,所屬關(guān)系有三種類型:一對一(one-to-one)、一對多(one-to-many)和多對多(many-to-many)。
// 一對一的例子 CREATE TABLE Author ( author_id INT PRIMARY KEY, author_name VARCHAR(50) ); CREATE TABLE Book ( book_id INT PRIMARY KEY, book_name VARCHAR(50), author_id INT, FOREIGN KEY (author_id) REFERENCES Author(author_id) ); // 一對多的例子 CREATE TABLE Department ( dept_id INT PRIMARY KEY, dept_name VARCHAR(50) ); CREATE TABLE Employee ( emp_id INT PRIMARY KEY, emp_name VARCHAR(50), emp_dept INT, FOREIGN KEY (emp_dept) REFERENCES Department(dept_id) ); // 多對多的例子 CREATE TABLE Student ( stu_id INT PRIMARY KEY, stu_name VARCHAR(50) ); CREATE TABLE Course ( course_id INT PRIMARY KEY, course_name VARCHAR(50) ); CREATE TABLE Student_Course ( stu_id INT, course_id INT, PRIMARY KEY (stu_id, course_id), FOREIGN KEY (stu_id) REFERENCES Student(stu_id), FOREIGN KEY (course_id) REFERENCES Course(course_id) );
以上是三種所屬關(guān)系的示例代碼。在一對一關(guān)系中,每個作者只能寫一本書,每本書也只能由一個作者編寫。在一對多關(guān)系中,一個部門可以有多個員工,但一個員工只能屬于一個部門。而在多對多關(guān)系中,一個學(xué)生可以選修多門課程,一門課程也可以被多個學(xué)生選修。
所屬關(guān)系是數(shù)據(jù)庫設(shè)計(jì)中非常重要的一環(huán),正確的關(guān)系設(shè)計(jì)可以提高數(shù)據(jù)庫的性能、可擴(kuò)展性和數(shù)據(jù)完整性。