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源代码
Oct 09 PHP
windows xp下安装pear
Dec 02 PHP
基于php-fpm 参数的深入理解
Jun 03 PHP
解析Ubuntu下crontab命令的用法
Jun 24 PHP
Smarty中调用FCKeditor的方法
Oct 27 PHP
详谈PHP编码转换问题
Jul 28 PHP
详谈php静态方法及普通方法的区别
Oct 04 PHP
浅谈PHP拦截器之__set()与__get()的理解与使用方法
Oct 18 PHP
php使用Jpgraph创建3D饼形图效果示例
Feb 15 PHP
Laravel学习笔记之Artisan命令生成自定义模板的方法
Nov 22 PHP
laravel5.1 ajax post 传值_token示例
Oct 24 PHP
Laravel框架实现抢红包功能示例
Oct 31 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个人网站架设连环讲(四)
2006/10/09 PHP
php AJAX实例根据邮编自动完成地址信息
2008/11/23 PHP
php 正则表达式小结
2009/08/31 PHP
约瑟夫环问题的PHP实现 使用PHP数组内部指针操作函数
2010/10/12 PHP
php将gd生成的图片缓存到memcache的小例子
2013/06/05 PHP
PHP实现获取FLV文件的时间
2015/02/10 PHP
PHP的关于变量和日期处理的一些面试题目整理
2015/08/10 PHP
php简单实现批量上传图片的方法
2016/05/09 PHP
PHP登录验证码的实现与使用方法
2016/07/07 PHP
Yii框架防止sql注入,xss攻击与csrf攻击的方法
2016/10/18 PHP
PHP实现UTF8二进制及明文字符串的转化功能示例
2017/11/20 PHP
thinkPHP框架实现多表查询的方法
2018/06/14 PHP
PHP实时统计中文字数和区别
2019/02/28 PHP
javascript SocialHistory 检查访问者是否访问过某站点
2008/08/02 Javascript
IE6-IE9中tbody的innerHTML不能赋值的解决方法
2014/09/26 Javascript
深入浅析JavaScript面向对象和原型函数
2016/02/06 Javascript
原生js制作日历控件实例分享
2016/04/06 Javascript
jquery动态切换背景图片的简单实现方法
2016/05/14 Javascript
easyui messager alert 三秒后自动关闭提示的实例
2016/11/07 Javascript
使用vue的v-for生成table并给table加上序号的实例代码
2017/10/27 Javascript
Angular中使用MathJax遇到的一些问题
2017/12/15 Javascript
微信小程序实现全国机场索引列表
2018/01/31 Javascript
原生JS实现旋转轮播图+文字内容切换效果【附源码】
2018/09/29 Javascript
通过JS深度判断两个对象字段相同
2019/06/14 Javascript
python实现ipsec开权限实例
2014/11/11 Python
Python中用Spark模块的使用教程
2015/04/13 Python
利用matplotlib+numpy绘制多种绘图的方法实例
2017/05/03 Python
numpy数组之存取文件的实现示例
2019/05/24 Python
Myprotein俄罗斯官网:欧洲第一运动营养品牌
2019/05/05 全球购物
屈臣氏越南官网:Watsons越南
2021/01/14 全球购物
软件设计的目标是什么
2016/12/04 面试题
给物业的表扬信
2014/01/21 职场文书
校园广播稿500字
2014/02/04 职场文书
干部选拔任用方案
2014/05/26 职场文书
MySQL 角色(role)功能介绍
2021/04/24 MySQL
redis实现共同好友的思路详解
2021/05/26 Redis