cari
Rumahpangkalan datatutorial mysqlBagaimanakah Saya Boleh Menyimpan dan Mendapatkan Berbilang Pendaftaran Kursus dengan Cekap untuk Pelajar dalam Pangkalan Data MySQL?

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

Merancang Pangkalan Data untuk Menyimpan Berbilang Pilihan dalam Jadual Tunggal

Pernyataan Masalah:

Dalam aplikasi pengiraan hasil, adalah perlu untuk menyimpan berbilang kursus yang dikaitkan dengan setiap pelajar dalam pangkalan data MySQL. Pelajar boleh mempunyai bilangan kursus yang berubah-ubah yang dilampirkan pada mereka, membentangkan cabaran tentang cara mereka bentuk struktur pangkalan data yang membolehkan penyimpanan dan mendapatkan semula kursus ini dengan cekap.

Penyelesaian: Jadual Persimpangan

Menyimpan data dalam tatasusunan mungkin kelihatan seperti pendekatan yang mudah, tetapi ia boleh mengakibatkan masalah prestasi dan penyelenggaraan yang lemah kerana kekurangan pengindeksan dalam MySQL. Sebaliknya, pendekatan yang disyorkan ialah menggunakan jadual Junction.

Jadual Junction ialah jadual yang memautkan dua jadual lain dengan merapatkan kekunci utamanya. Dalam kes ini, jadual SCJunction (Simpang Pelajar/Kursus) boleh dibuat dengan lajur berikut:

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

Lajur studentId dan courseId ialah kunci asing yang merujuk kepada jadual Pelajar dan Kursus, masing-masing. Lajur istilah akan menunjukkan istilah di mana kursus itu diambil.

Dengan menggunakan jadual Junction, setiap pelajar boleh mempunyai berbilang kursus yang dikaitkan dengannya dan setiap kursus boleh diambil oleh berbilang pelajar. Lajur kehadiran dan gred boleh digunakan untuk menyimpan maklumat tambahan tentang setiap pendaftaran.

Skema Contoh

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

Pengindeksan Data

Indeks komposit pada jadual SCJunction akan meningkatkan prestasi untuk pertanyaan yang mendapatkan data berdasarkan kedua-dua studentId dan courseId. Untuk pertanyaan yang mencari mengikut istilah pendaftaran, indeks pada lajur istilah juga akan bermanfaat.

Kelebihan Jadual Persimpangan

  • Integriti Rujukan: Jadual persimpangan menguatkuasakan integriti rujukan, memastikan pelajar dan kursus wujud dalam pangkalan data sebelum mereka boleh didaftarkan dalam jadual SCJunction.
  • Peluasan Mudah: Jadual simpang membenarkan penambahan lajur baharu dengan mudah untuk data tambahan.
  • Storan Cekap: Jadual simpang boleh mengurangkan ruang storan dengan mengelakkan pertindihan data.
  • Hubungan Fleksibel: Jadual persimpangan boleh digunakan untuk mewakili perhubungan banyak-ke-banyak antara sebarang bilangan jadual.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menyimpan dan Mendapatkan Berbilang Pendaftaran Kursus dengan Cekap untuk Pelajar dalam Pangkalan Data MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Menambah Pengguna ke MySQL: Tutorial LengkapMenambah Pengguna ke MySQL: Tutorial LengkapMay 12, 2025 am 12:14 AM

Menguasai kaedah menambah pengguna MySQL adalah penting untuk pentadbir pangkalan data dan pemaju kerana ia memastikan keselamatan dan kawalan akses pangkalan data. 1) Buat pengguna baru menggunakan perintah CreateUser, 2) Berikan kebenaran melalui perintah geran, 3) Gunakan flushprivileges untuk memastikan kebenaran berkuatkuasa, 4) kerap mengaudit dan membersihkan akaun pengguna untuk mengekalkan prestasi dan keselamatan.

Menguasai Jenis Data String MySQL: Varchar vs Text vs. CharMenguasai Jenis Data String MySQL: Varchar vs Text vs. CharMay 12, 2025 am 12:12 AM

ChooseCHARforfixed-lengthdata,VARCHARforvariable-lengthdata,andTEXTforlargetextfields.1)CHARisefficientforconsistent-lengthdatalikecodes.2)VARCHARsuitsvariable-lengthdatalikenames,balancingflexibilityandperformance.3)TEXTisidealforlargetextslikeartic

MySQL: Jenis Data String dan Pengindeksan: Amalan TerbaikMySQL: Jenis Data String dan Pengindeksan: Amalan TerbaikMay 12, 2025 am 12:11 AM

Amalan terbaik untuk mengendalikan jenis data rentetan dan indeks dalam MySQL termasuk: 1) Memilih jenis rentetan yang sesuai, seperti char untuk panjang tetap, varchar untuk panjang berubah, dan teks untuk teks besar; 2) berhati-hati dalam pengindeksan, elakkan daripada mengindeks, dan buat indeks untuk pertanyaan umum; 3) Gunakan indeks awalan dan indeks teks penuh untuk mengoptimumkan carian rentetan panjang; 4) Secara kerap memantau dan mengoptimumkan indeks untuk memastikan indeks kecil dan cekap. Melalui kaedah ini, kita dapat mengimbangi membaca dan menulis prestasi dan meningkatkan kecekapan pangkalan data.

Mysql: Cara menambah pengguna dari jauhMysql: Cara menambah pengguna dari jauhMay 12, 2025 am 12:10 AM

Toaddauserremotelytomysql, ikuti: 1) connecttomysqlasroot, 2) createeanewuserwithremoteaccess, 3) grantnessaryaryprivileges, dan4)

Panduan Ultimate untuk Jenis Data String MySQL: Penyimpanan Data CekapPanduan Ultimate untuk Jenis Data String MySQL: Penyimpanan Data CekapMay 12, 2025 am 12:05 AM

TostoreStringsefficientlyinmysql, choosetherightdatypebasedonyonoeds: 1) usecharforfixed-lengtstringslikecountrycodes.2) usevarcharfarfarable-lengtstringslikENAMES.3)

MySQL Blob vs Text: Memilih Jenis Data yang Tepat Untuk Objek BesarMySQL Blob vs Text: Memilih Jenis Data yang Tepat Untuk Objek BesarMay 11, 2025 am 12:13 AM

Apabila memilih jenis gumpalan dan jenis data MySQL, gumpalan sesuai untuk menyimpan data binari, dan teks sesuai untuk menyimpan data teks. 1) Gumpalan sesuai untuk data binari seperti gambar dan audio, 2) Teks sesuai untuk data teks seperti artikel dan komen. Apabila memilih, sifat data dan pengoptimuman prestasi mesti dipertimbangkan.

MySQL: Sekiranya saya menggunakan pengguna root untuk produk saya?MySQL: Sekiranya saya menggunakan pengguna root untuk produk saya?May 11, 2025 am 12:11 AM

Tidak, yoShouldnotusherootuserinmysqlforyourproduct.Instead, createspecificuserswithlimitedprivilegestoenhancesecurityandperformance: 1) createanewuserwithastrongpassword, 2) GrantonLyNessarypermissionStothiser, 3) secara teratur danReviewandupdateerererererword,

Jenis Data String MySQL Diterangkan: Memilih jenis yang sesuai untuk data andaJenis Data String MySQL Diterangkan: Memilih jenis yang sesuai untuk data andaMay 11, 2025 am 12:10 AM

Mysqlstringdatatypesshouldbechosenbasedondatacharacteristicsandusecases: 1) usecharforfixed-lengthstringslikecountrycodes.2) usevarcharfarfarable-lengtstringslikeNames.3) Usebinerorvarbinarbinarbinarbinarsstographceys.2)

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Nordhold: Sistem Fusion, dijelaskan
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Cara Membuka Kunci Cangkuk Bergelut
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

SublimeText3 versi Inggeris

SublimeText3 versi Inggeris

Disyorkan: Versi Win, menyokong gesaan kod!

EditPlus versi Cina retak

EditPlus versi Cina retak

Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Persekitaran pembangunan bersepadu PHP yang berkuasa

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat ialah persekitaran pelayar selamat untuk mengambil peperiksaan dalam talian dengan selamat. Perisian ini menukar mana-mana komputer menjadi stesen kerja yang selamat. Ia mengawal akses kepada mana-mana utiliti dan menghalang pelajar daripada menggunakan sumber yang tidak dibenarkan.

VSCode Windows 64-bit Muat Turun

VSCode Windows 64-bit Muat Turun

Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft