0

我正在开发我的 PHP 项目 [处理学生考勤系统]。我有一个学生列表以及他们的 id[jntuno],我需要在 mysql 中创建一个数据库来存储每个学生对每个科目的每日出勤率。所以我以这种方式创建了我的表:

桌子 :students

领域:

slno int(5) auto increment,
jntuno char(15),
name char(50),
primary key(slno,jntuno).

数据:

学生表中的数据

students表包含学生列表及其 ID

现在我创建了另一个表:

桌子:dailyatt

领域:

date date,
subject char(10),
classesconducted int(2),
`11341A0501` int(2),
`11341A0502` int(2),
`11341A0503` int(2),
.
.
.
`11341A0537` int(2),
primary key(date,subject).

这张表看起来像:

+------------+-----------+-----------------+------------+-----------+-----------+
|date        |subject    |classesconducted |11341A0501  |11341A0502 |11341A0503 |....
+------------+-----------+-----------------+------=-----+-----------+-----------+
|            |           |                 |            |           |           |

现在每天在 PHP 网站上输入出勤率,都会为当天教授的每个科目创建一个新行。

但是很多人说数据库模型不好……
这个数据库结构有什么问题?

那么有人可以为我推荐一个更好的模型来解决这类问题吗?

4

2 回答 2

4

想象一下,您的学校有 200 名学生。您的第二个表中将有 200 多列。你应该把它分成两个表。一个用于学校提供的所有课程,第二个用于实际出勤记录。

“类”表

在此处输入图像描述

《考勤表》

在此处输入图像描述

然后将它们连接在一起。

SELECT student_id, class_name, date, class_attended
FROM attendance AS ABB2
    LEFT JOIN classes AS ABB1 ON ABB1.id = ABB2.class_id 
于 2013-10-06T10:31:28.463 回答
2

您正在为每个学生创建一个专栏,我认为这是一件坏事。

为什么你不创建这样的表?

`date` date,
`slno` int(5),
`slnoconducted` int(2),
`subject` char(10),
primary key(`date`, `slno`, `subject`)

因此,您可以在此表中插入一些值,例如:

("2013-10-06", 1, 5, "Class A")

它将被视为:截至 2013 年 10 月 6 日,slno #1 (11341A0501) 的学生获得了 slnoconducted == 5,描述为“A 级”。

之后,例如,如果您想获取今天的所有记录,您可以使用查询:

SELECT * FROM dailyatt WHERE `date` = '2013-10-06'

如果要获取一个学生的所有记录,可以使用查询:

SELECT * FROM dailyatt WHERE `slno` = 1

乃至:

SELECT d.*, s.`jntuno`, s.`name` 
FROM `dailyatt` d
LEFT JOIN `students` s ON d.`slno` = s.`slno`
WHERE `date` = '2013-10-06'

这是处理记录的更好方法。如果您为每个学生创建列,您将失去数据库的灵活性,因为您必须在表中发生任何更改后创建/删除另一列students

我希望我描述正确,因为我不确定我的英语是否良好。

于 2013-10-06T10:19:24.900 回答