ThinkPHP5实现作业管理系统中处理学生未交作业与已交作业信息的方法


Posted in PHP onNovember 12, 2016

本文实例讲述了ThinkPHP5实现作业管理系统中处理学生未交作业与已交作业信息的方法。分享给大家供大家参考,具体如下:

在作业管理系统中,学生登陆到个人中心后可以通过左侧的菜单查看自己已经提交的作业和未提交作业。那么在系统中如何实现这些数据的查询的呢?首先我们需要弄清楚学生(Student)、班级(class)、作业提交表(Submit)这三个表之间的关系。

1. 每个学生都属于一个班级

2. 班级里的每个学生都会被布置同样的作业

3. 学生提交作业后会在作业提交表中添加响应的记录,如学生的ID,作业的ID,提交的内容等。

可以按照以下步骤获取学生已交作业和未交作业

1. 获取学生所在班级的所有作业

//获取学生所在班级的所有作业
 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建立学生作业管理系统实践中对学生作业列表的解决办法,如果您有更好的方法,欢迎批评指正!

希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。

PHP 相关文章推荐
PHP容易被忽略而出错陷阱 数字与字符串比较
Nov 10 PHP
初品cakephp 入门基础
Feb 16 PHP
PHP中如何调用webservice的实例参考
Apr 25 PHP
分享下PHP register_globals 值为on与off的理解
Sep 26 PHP
php异常处理使用示例
Feb 25 PHP
php读取csv文件并输出的方法
Mar 14 PHP
php实现Session存储到Redis
Nov 11 PHP
Yii+upload实现AJAX上传图片的方法
Jul 13 PHP
laravel 数据迁移与 Eloquent ORM的实现方法
Apr 12 PHP
Laravel框架实现简单的学生信息管理平台案例
May 07 PHP
YII2框架中添加自定义模块的方法实例分析
Mar 18 PHP
PHP生成随机密码4种方法及性能对比
Dec 11 PHP
php array_values 返回数组的所有值详解及实例
Nov 12 #PHP
php array_udiff_assoc 计算两个数组的差集实例
Nov 12 #PHP
PHP上传图片、删除图片简单实例
Nov 12 #PHP
PHP防止图片盗用(盗链)的方法小结
Nov 11 #PHP
PHP数据的提交与过滤基本操作实例详解
Nov 11 #PHP
thinkPHP多语言切换设置方法详解
Nov 11 #PHP
thinkPHP中钩子的两种配置调用方法详解
Nov 11 #PHP
You might like
php使用base64加密解密图片示例分享
2014/01/20 PHP
WordPress中转义HTML与过滤链接的相关PHP函数使用解析
2015/12/22 PHP
php设计模式之状态模式实例分析【星际争霸游戏案例】
2020/03/26 PHP
关闭浏览器时提示onbeforeunload事件
2013/12/25 Javascript
JS中怎样判断undefined(比较不错的方法)
2014/03/27 Javascript
一些老手都不一定知道的JavaScript技巧
2014/05/06 Javascript
JS给超链接加确认对话框的方法
2015/02/24 Javascript
js实现适用于素材网站的黑色多级菜单导航条效果
2015/08/24 Javascript
js微信分享API
2020/10/11 Javascript
详解前端路由实现与react-router使用姿势
2017/08/07 Javascript
解决vue 使用setTimeout,离开当前路由setTimeout未销毁的问题
2020/07/21 Javascript
使用python绘制人人网好友关系图示例
2014/04/01 Python
Python中模拟enum枚举类型的5种方法分享
2014/11/22 Python
python创建和删除目录的方法
2015/04/29 Python
socket + select 完成伪并发操作的实例
2017/08/15 Python
用不到50行的Python代码构建最小的区块链
2017/11/16 Python
Python 获取主机ip与hostname的方法
2018/12/17 Python
Python 判断图像是否读取成功的方法
2019/01/26 Python
python自定义函数实现最大值的输出方法
2019/07/09 Python
python3.5 cv2 获取视频特定帧生成jpg图片
2019/08/28 Python
PyCharm专业最新版2019.1安装步骤(含激活码)
2019/10/09 Python
python 使用opencv 把视频分割成图片示例
2019/12/12 Python
印度尼西亚手表和包包商店:Urban Icon
2019/12/12 全球购物
如何在发生故障的节点上重新安装 SQL Server
2013/03/14 面试题
C#如何调用Windows程序打开一个文档
2014/12/26 面试题
大学生全国两会报告感想
2014/03/17 职场文书
法律系毕业生自荐信范文
2014/03/27 职场文书
股东协议书
2014/04/14 职场文书
协议书的格式
2014/04/23 职场文书
单位法定代表人授权委托书
2014/09/20 职场文书
销售员未完成销售业绩的检讨书
2014/10/12 职场文书
财政局党的群众路线教育实践活动剖析材料
2014/10/13 职场文书
公务员群众路线心得体会
2014/11/03 职场文书
创建文明城市倡议书
2015/04/28 职场文书
2015年电信员工工作总结
2015/05/26 职场文书
2016幼儿园教师年度考核评语
2015/12/01 职场文书