model = new \app\admin\model\manage\statics\Film; } /** * 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法 * 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑 * 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改 */ /** * 查看 */ public function index() { //设置过滤方法 $this->request->filter(['strip_tags']); if ($this->request->isAjax()) { //如果发送的来源是Selectpage,则转发到Selectpage if ($this->request->request('keyField')) { return $this->selectpage(); } // 过滤机构 $childInsIds = $this->auth->getMyInsId(); if($childInsIds == false){ $more = false; } else { $more = ['e.institution_id' => ['in', $childInsIds]]; } $field = ['name,institution_id,e.depart,e.exam_class as device,q.study_result,q.study_score']; $ins = Db::table('institution')->cache('allins',180)->column('id,name'); list($where, $sort, $order, $offset, $limit) = $this->buildparams(); $total = $this->model ->alias('q') ->join(['exams'=>'e'],'e.id=q.exam_id') ->where("q.type = 1 or q.type = 3") ->where('task_type',1) ->where($where) ->where($more) ->order($sort, $order) ->count(); $list = $this->model ->alias('q') ->join(['exams'=>'e'],'e.id=q.exam_id') ->where("q.type = 1 or q.type = 3") ->where('task_type',1) ->where($where) ->where($more) ->field($field) ->order($sort, $order) ->limit($offset, $limit) ->select(); $list = collection($list)->toArray(); foreach ($list as $k=>$v) { $list[$k]['institution_name'] = $ins[$v['institution_id']] ?? ''; } $result = array("total" => $total, "rows" => $list); return json($result); } return $this->view->fetch(); } }