query()->insertGetId($data); // 如果操作失败 if( !$id ) return $id; // 更新缓存 if( isset($data['course_id']) ) $this->getList($data['course_id'],true); // 返回结果 return $id; } /** * 添加数据 * */ public function edit($id,$data) { // 更新时间 $data['update_time'] = time(); // 写入数据表 $result = $this->query()->where(['id'=>$id])->update($data); // 如果操作失败 if( !$result ) return $id; // 更新缓存 if( isset($data['course_id']) ) $this->getList($data['course_id'],true); // 返回结果 return $id; } /** * 获取列表 * @param Bool $force 是否强制更新 * */ public function getList($courseId,$force = false) { // 结果数据 $list = $force ? [] : cache('admin:video:exam:question:list:'.$courseId); // 不存在数据 if ( !$list ) { // 从数据库获取数据 $data = $this->query()->where([['status','=',0],['course_id','=',$courseId]])->get(['id','course_id','question_id'])->toArray(); // 循环处理数据 $list = []; // 进行更新 foreach ($data as $value) { // 重组数据 $list[$value['question_id']] = $value; } // 存起来 cache(['admin:video:exam:question:list:'.$courseId=>$list]); } // 返回结果 return $list; } /** * 获取配置平台对应的应用数据 * * @param int $courseId 课程ID * @param int $questionId 问题ID * @param string $field 字段名 * */ public function getOne($courseId,$questionId,$field='') { // 获取列表数据 $list = $this->getList($courseId); // 获取数据 $one = isset($list[$questionId]) ? $list[$questionId] : []; // 返回值 return empty($field) ? $one : ( isset($one[$field]) ? $one[$field] : null); } }