如何設計MySQL表結構來支援線上考試系統的考試成績統計?
簡介
線上考試系統是現代教育的重要組成部分之一。為了對學生的考試成績進行統計和分析,需要設計適合的資料庫表結構來儲存考試資訊。本文將介紹如何設計MySQL表結構來支援線上考試系統的考試成績統計,並提供具體的程式碼範例。
表格結構設計
在設計MySQL表結構時,需要考慮學生、考試、試題和成績等因素。以下是一個簡單的表格結構設計範例。
學生表(students)
欄位名稱 | 資料型別 | ##說明|
---|---|---|
INT | 學生ID | |
##VARCHAR | 學生姓名 | |
VARCHAR | ||
VARCHAR | 班級 | |
#DATETIME | 由學生資訊所建立的時間 |
欄位名稱 | 資料型別 | ##說明|
id | INT | |
name | VARCHAR | |
time | DATETIME | |
科目 | VARCHAR |
考試資訊所建立的時間 | ||
---|---|---|
#欄位名稱 | 資料類型 | ##說明 |
id | INT | |
exam_id | INT | |
content | TEXT | |
##答案 | VARCHAR | 正確答案 |
建立時間
成績表(scores) | ||
---|---|---|
資料類型 | 說明 | |
id | INT | 成績ID |
student_id | INT | 學生ID |
exam_id | INT | 考試ID |
## score | FLOAT | 成績 |
DATETIME
SELECT e.name AS exam_name, s.score FROM scores AS s JOIN exams AS e ON s.exam_id = e.id WHERE s.student_id = <student_id>;
SELECT AVG(score) AS average_score FROM scores AS s WHERE s.exam_id = <exam_id>;
查詢某次考試不及格的學生名單
SELECT st.name AS student_name, s.score FROM scores AS s JOIN students AS st ON s.student_id = st.id WHERE s.exam_id = <exam_id> AND s.score < <passing_score>;
SELECT COUNT(*) AS count, CASE WHEN score >= 90 THEN 'A' WHEN score >= 80 THEN 'B' WHEN score >= 70 THEN 'C' WHEN score >= 60 THEN 'D' ELSE 'F' END AS grade FROM scores WHERE exam_id = <exam_id> GROUP BY grade;
以上是如何設計MySQL表結構來支援線上考試系統的考試成績統計?的詳細內容。更多資訊請關注PHP中文網其他相關文章!