在MySQL中,中間表是指用于建立多對多關(guān)系的表。在中間表中,通常會存在兩個主鍵,以便記錄數(shù)據(jù)之間的關(guān)系。
為了更好地理解中間表中存在兩個主鍵的原因,我們可以舉一個例子。假設(shè)有一張學(xué)生表和一張課程表,但是每個學(xué)生可以選擇多門課程,同樣一門課程也可以被多個學(xué)生所選。為了建立這樣的多對多關(guān)系,我們需要引入一張中間表,包括學(xué)生ID和課程ID兩個字段,這兩個字段作為中間表的主鍵,記錄每個學(xué)生所選的所有課程,以及每門課程的所有學(xué)生。
CREATE TABLE student ( id INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY, name VARCHAR(50) NOT NULL, age INT NOT NULL, gender TINYINT NOT NULL DEFAULT 0 ); CREATE TABLE course ( id INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY, name VARCHAR(50) NOT NULL, teacher VARCHAR(50) NOT NULL, credit FLOAT NOT NULL DEFAULT 0.0 ); CREATE TABLE student_course ( student_id INT UNSIGNED NOT NULL, course_id INT UNSIGNED NOT NULL, PRIMARY KEY (student_id, course_id), FOREIGN KEY (student_id) REFERENCES student (id), FOREIGN KEY (course_id) REFERENCES course (id) );
在這個例子中,我們通過中間表student_course建立了學(xué)生和課程之間的多對多關(guān)系。中間表的兩個字段student_id和course_id作為主鍵,可以同時記錄一名學(xué)生選了哪些課程,以及一門課程有哪些學(xué)生選擇。
除了使用中間表來建立多對多關(guān)系之外,我們還可以通過外鍵約束來確保數(shù)據(jù)的完整性和一致性。在上面的示例中,我們使用外鍵約束來保證中間表中的student_id和course_id字段均來自于student和course表中已經(jīng)存在的數(shù)據(jù),從而避免了中間表中出現(xiàn)不存在的記錄。