ThinkPHP5作业管理系统中处理学生未交作业与已交作业信息
2016-11-03 11:29
405 查看
在作业管理系统中,学生登陆到个人中心后可以通过左侧的菜单查看自己已经提交的作业和未提交作业。那么在系统中如何实现这些数据的查询的呢?首先我们需要弄清楚学生(Student)、班级(class)、作业提交表(Submit)这三个表之间的关系。
每个学生都属于一个班级
班级里的每个学生都会被布置同样的作业
学生提交作业后会在作业提交表中添加响应的记录,如学生的ID,作业的ID,提交的内容等。
可以按照以下步骤获取学生已交作业和未交作业
获取学生所在班级的所有作业
由上述代码课看出,首先根据学号($stuno)获取学生信息,通过学生信息表保存的班级ID(clas_id)再获取学生所在班级信息,最后通过班级与作业表之间的多对多的关系(详见Thinkphp5官方手册关于模型的关联部分内容),获取该学生所在班级所布置的所有作业。
2. 获取学生未交作业
该函数首先调用获取全部作业的函数($this->getTasks($stuno))获得了学生所在班级的所有作业。这个数据集是一个二维数组,遍历这个二维数组,看看这个二维数组中是否有作业已经被该学生提交到了Submit中,如果提交了就删除该元素。
3.获得学生已交作业
有了上述两个函数,获取已交作业的事情就变的简单了,第一个函数获得的二维数组减去第二个函数所返回的数组就是学生已交作业的集合,做下二维数组的求差即可
以上就是我在使用ThinkPHP5建立学生作业管理系统实践中对学生作业列表的解决办法,如果您有更好的方法,欢迎批评指正!
本文首发 顶求网,转载请注明来源!
每个学生都属于一个班级
班级里的每个学生都会被布置同样的作业
学生提交作业后会在作业提交表中添加响应的记录,如学生的ID,作业的ID,提交的内容等。
可以按照以下步骤获取学生已交作业和未交作业
获取学生所在班级的所有作业
//获取学生所在班级的所有作业 public function getTasks($stuno) { $stu=$this::get(['stu_no'=>$stuno]); $clas=Clas::get(['clas_id'=>$stu['clas_id']]); return $clas->task; }
由上述代码课看出,首先根据学号($stuno)获取学生信息,通过学生信息表保存的班级ID(clas_id)再获取学生所在班级信息,最后通过班级与作业表之间的多对多的关系(详见Thinkphp5官方手册关于模型的关联部分内容),获取该学生所在班级所布置的所有作业。
2. 获取学生未交作业
//获取某学生所有未交作业 public function getUnSubmitTasks($stuno) { $stu=$this::get(['stu_no'=>$stuno]); $alltask=$this->getTasks($stuno); foreach($alltask as $key=>$value) { if(Submit::get(['task_id'=>$value['task_id'],'stu_id'=>$stu['stu_id']])) { unset($alltask[$key]);//删除已提交作业 } } return $alltask; }
该函数首先调用获取全部作业的函数($this->getTasks($stuno))获得了学生所在班级的所有作业。这个数据集是一个二维数组,遍历这个二维数组,看看这个二维数组中是否有作业已经被该学生提交到了Submit中,如果提交了就删除该元素。
3.获得学生已交作业
有了上述两个函数,获取已交作业的事情就变的简单了,第一个函数获得的二维数组减去第二个函数所返回的数组就是学生已交作业的集合,做下二维数组的求差即可
//获取某学生所有已交作业(所有作业和未交作业的差集) public function getSubmitTasks($stuno) { $unsubmit=$this->getUnSubmitTasks($stuno); $alltasks=$this->getTasks($stuno); $submittasks=array(); foreach ($alltasks as $key=>$value) { if(!in_array($value,$unsubmit)) { $submittasks[]=$value; } } return $submittasks; }
以上就是我在使用ThinkPHP5建立学生作业管理系统实践中对学生作业列表的解决办法,如果您有更好的方法,欢迎批评指正!
本文首发 顶求网,转载请注明来源!
相关文章推荐
- ThinkPHP5实现作业管理系统中处理学生未交作业与已交作业信息的方法
- ThinkPHP5实现作业管理系统中处理学生未交作业与已交作业信息的方法
- ThinkPHP5实现作业管理系统中处理学生未交作业与已交作业信息的方法
- C++学生信息管理系统V1(课后作业)
- [置顶] 学生信息管理系统-C语言结课作业掺杂了一点c++
- 大作业 :学生信息管理系统。。。
- SQL_学生信息管理系统验收 时实错误"91”处理
- MVC框架——学生信息管理系统(多表,多事务如何处理,一个用户如何共用一个Connection连接)
- 学生信息管理系统-顺序表&&链表(数据结构第一次作业)
- 数据结构第一次作业(学生信息管理系统-顺序表&&链表)
- 学生信息管理系统之优化处理
- 学生信息管理系统(二)----错误处理
- 2013年大一上学期的C++大作业 学生信息管理系统
- 学生信息管理系统-C#课程设计
- 【原创视频教程】学生信息管理系统1--登陆
- 【原创视频教程】学生信息管理系统5--学员成绩管理
- [VB.NET源码]学生信息管理系统
- 【原创视频教程】学生信息管理系统6--学员信息管理(完结篇)
- 【原创视频教程】学生信息管理系统4--成绩添加