ホームページ >データベース >mysql チュートリアル >学生の複数のコース登録情報を MySQL データベースに効率的に保存および取得するにはどうすればよいですか?

学生の複数のコース登録情報を MySQL データベースに効率的に保存および取得するにはどうすればよいですか?

Susan Sarandon
Susan Sarandonオリジナル
2024-12-16 10:09:091062ブラウズ

How Can I Efficiently Store and Retrieve Multiple Course Enrollments for Students in a MySQL Database?

単一テーブルに複数のオプションを格納するデータベースの設計

問題ステートメント:

結果計算アプリケーションでは、各学生に関連付けられた複数のコースを MySQL データベースに保存する必要があります。学生は可変の数のコースを関連付けることができるため、これらのコースの効率的な保存と検索を可能にするデータベース構造をどのように設計するかという課題が生じます。

解決策: ジャンクション テーブル

データを配列に保存するのは単純なアプローチのように思えるかもしれませんが、MySQL にはインデックスがないため、パフォーマンスの低下やメンテナンスの問題が発生する可能性があります。代わりに、ジャンクション テーブルを使用することをお勧めします。

ジャンクション テーブルは、主キーをブリッジして他の 2 つのテーブルをリンクするテーブルです。この場合、SCJunction (Student/Course Connection) テーブルは次の列を使用して作成できます。

SCJunction
| id | studentId | courseId | term | attendance | grade |

studentId 列と courseId 列は、それぞれ Student テーブルと Course テーブルを参照する外部キーになります。期間列は、コースが受講された期間を示します。

ジャンクション テーブルを使用すると、各学生に複数のコースを関連付けることができ、各コースを複数の学生が受講することができます。出席と成績の列を使用して、各登録に関する追加情報を保存できます。

スキーマの例

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)
);

データのインデックス作成

SCJunction テーブルの複合インデックスにより、studentId と StudentId の両方に基づいてデータを取得するクエリのパフォーマンスが向上します。コースID。登録用語で検索するクエリの場合、用語列のインデックスも有益です。

ジャンクション テーブルの利点

  • 参照整合性: ジャンクション テーブルは参照整合性を強制し、学生とコースがデータベースに登録される前に確実に存在するようにします。 SCJunction テーブル。
  • 簡単な拡張: ジャンクション テーブルでは、追加データ用に新しい列を簡単に追加できます。
  • 効率的なストレージ: ジャンクション テーブルは、データの重複を回避してストレージ容量を削減します。
  • 柔軟リレーションシップ: ジャンクション テーブルを使用して、任意の数のテーブル間の多対多のリレーションシップを表すことができます。

以上が学生の複数のコース登録情報を MySQL データベースに効率的に保存および取得するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。