Problemstellung:
In einer Ergebnisberechnungsanwendung: Es ist notwendig, mehrere mit jedem Studenten verknüpfte Kurse in einer MySQL-Datenbank zu speichern. Den Studierenden kann eine variable Anzahl von Kursen zugeordnet sein, was die Herausforderung darstellt, eine Datenbankstruktur zu entwerfen, die eine effiziente Speicherung und den Abruf dieser Kurse ermöglicht.
Lösung: Verbindungstabellen
Das Speichern von Daten in Arrays scheint ein unkomplizierter Ansatz zu sein, kann jedoch aufgrund der fehlenden Indizierung in MySQL zu schlechter Leistung und Wartungsproblemen führen. Stattdessen wird die Verwendung von Junction-Tabellen empfohlen.
Eine Junction-Tabelle ist eine Tabelle, die zwei andere Tabellen durch Überbrücken ihrer Primärschlüssel verknüpft. In diesem Fall kann eine SCJunction-Tabelle (Student/Course Junction) mit den folgenden Spalten erstellt werden:
SCJunction | id | studentId | courseId | term | attendance | grade |
Die Spalten studentId und courseId wären Fremdschlüssel, die jeweils auf die Tabellen Student und Course verweisen. Die Semesterspalte würde das Semester angeben, in dem der Kurs belegt wurde.
Durch die Verwendung einer Junction-Tabelle können jedem Studenten mehrere Kurse zugeordnet werden, und jeder Kurs kann von mehreren Studenten belegt werden. In den Spalten „Anwesenheit“ und „Note“ können zusätzliche Informationen zu jeder Anmeldung gespeichert werden.
Beispielschema
create table student ( studentId int auto_increment primary key, fullName varchar(100) not null ); create table dept ( deptId int auto_increment primary key, deptName varchar(100) not null ); create table course ( courseId int auto_increment primary key, deptId int not null, courseName varchar(100) not null, CONSTRAINT fk_crs_dept FOREIGN KEY (deptId) REFERENCES dept(deptId) ); create table SCJunction ( id int auto_increment primary key, studentId int not null, courseId int not null, term int not null, attendance int not null, grade int not null, unique key(studentId,courseId,term), key (courseId,studentId), CONSTRAINT fk_sc_student FOREIGN KEY (studentId) REFERENCES student(studentId), CONSTRAINT fk_sc_courses FOREIGN KEY (courseId) REFERENCES course(courseId) );
Datenindizierung
Zusammengesetzte Indizes für die SCJunction-Tabelle verbessern die Leistung für Abfragen, die Daten basierend auf studentId und courseId abrufen. Bei Abfragen, die nach Einschreibungsbegriffen suchen, wäre auch ein Index für die Begriffsspalte von Vorteil.
Vorteile von Verbindungstabellen
Das obige ist der detaillierte Inhalt vonWie kann ich mehrere Kursanmeldungen für Studierende effizient in einer MySQL-Datenbank speichern und abrufen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!