国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > PHP > 正文

thinkPHP多表查詢及分頁功能實現(xiàn)方法示例

2024-05-04 23:58:27
字體:
來源:轉載
供稿:網(wǎng)友

本文實例講述了thinkPHP多表查詢及分頁功能實現(xiàn)方法。分享給大家供大家參考,具體如下:

項目業(yè)務邏輯為:教師上傳試卷,設置答題卡,發(fā)布答題卡給相關的班級或群組,只有試卷關聯(lián)的答題卡發(fā)布后,該試卷才能在系統(tǒng)試卷中搜索到,同時其他的老師也可以收藏。在前端的收藏模塊中,有個業(yè)務是給個input框以提供搜索功能給用戶,但是在事先設計的搜索表中,只有一處試卷ID是和試卷表關聯(lián)的,如果用戶搜索試卷題目那豈不要兩表查詢了,一開始我想到的方法是在收藏表中多加個字段,也就是把試卷題目的字段添加到收藏表中,業(yè)務完成。今天在處理題庫分享的邏輯時,又發(fā)現(xiàn)了這個問題,看了下同事設計的分享表只有一個題庫ID,于是我便把同事叫過來“糾正”,但事先我還是想聽聽同事的設計思路,同事說量表查詢啊,我勒個去,看來我一張表查詢使用習慣了,沒有想到此種情況,被鄙視了,于是正視了自己的錯誤,當然了前提是說了下自己的思路,現(xiàn)在想來不怎么對,下面便給給出相關的tp代碼。

// 異步請求試卷夾下某一個試卷夾的列表public function ajaxLists() {  extract($_GET);  $page = intval($_GET['p']);  $prefix = C('DB_PREFIX');  $collect = $prefix . 'collect';  $resource = $prefix . 'resource';  if ($keyword) {    $arr = preg_split('/ /', $keyword);    // 搜索標簽    foreach ($arr as $value) {      $id = A('Home/Papers')->trunWordToId(array($value));      if ($id) {        $where['resource.rta_id'][] = array('LIKE', '%,' . $id . ',%');      }      $where['resource.re_title'][] = array('LIKE', '%' . $value . '%');    }    if ($where['resource.rta_id']) {      $where['resource.rta_id'][] = 'AND';    }    if ($where['resource.re_title']) {      $where['resource.re_title'][] = 'OR';    }    if ($where['resource.re_title'] && $where['resource.rta_id']) {      $where['_logic'] = 'OR';    }  }  if ($where) {    $map['_complex'] = $where;  }  $map['collect.a_id'] = $this->authInfo['a_id'];  $map['_string'] = 'collect.col_object_id = resource.re_id';  // 總數(shù)  $count = M()->table("$collect collect, $resource resource")->where($map)->count();  // 總頁數(shù)  $regNum = ceil($count/6);  // 驗證當前請求頁碼是否大于總頁數(shù)  $page = $page > $regNum ? $regNum : $page;  // 引入ajax分頁庫  import("@.ORG.Util.AjaxPage");  $Page = new AjaxPage($count, 6);  $list['page'] = trim($Page->show());  $list['list'] = M()->table("$collect collect, $resource resource")->where($map)->order('col_id DESC')->limit($Page->firstRow . ',' . $Page->listRows)->field('collect.col_id,collect.col_object_id,resource.re_id,resource.re_title,resource.re_created,resource.re_collect_count,resource.re_score_count,resource.re_score_num,resource.rta_id')->select();  // 獲取試卷的標簽  $wheree['rta_id'] = array('IN', trim(str_replace(',,', ',', implode('', getValueByField($list['list'], 'rta_id'))), ','));  $tag = setArrayByField(M('ResourceTag')->where($wheree)->field('rta_id,rta_title')->select(), 'rta_id');  // 把標簽和試卷對應  foreach ($list['list'] as $key => &$value) {    $str = '';    foreach ($tag as $k => $v) {      if (strpos($value['rta_id'], ',' . $k . ',') !== FALSE) {        $str .= ' | ' . $v['rta_title'];      }      $value['rta_title'] = trim($str, ' |');    }    if ($keyword) {      foreach ($arr as $vv) {        if (strpos($value['re_title'], $vv) !== FALSE) {          $value['re_title'] = str_replace($vv, '<font color=/'red/'>' . $vv . '</font>', $value['re_title']);        }        if (strpos($value['rta_title'], $vv) !== FALSE) {          $value['rta_title'] = str_replace($vv, '<font color=/'red/'>' . $vv . '</font>', $value['rta_title']);        }      }    }    $value['re_created'] = date('Y-m-d', $value['re_created']);  }  echo json_encode($list);}

希望本文所述對大家基于ThinkPHP框架的PHP程序設計有所幫助。


注:相關教程知識閱讀請移步到PHP教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 宝清县| 静乐县| 增城市| 临潭县| 林甸县| 灵璧县| 江山市| 金堂县| 建昌县| 平远县| 泽普县| 淮滨县| 盐山县| 江阴市| 徐州市| 宣武区| 英吉沙县| 禄丰县| 察隅县| 遵义市| 郴州市| 富民县| 登封市| 井陉县| 武胜县| 宁都县| 新津县| 勐海县| 汶上县| 尼木县| 固阳县| 盐津县| 新郑市| 岢岚县| 宜君县| 五寨县| 兴安盟| 承德市| 都江堰市| 永城市| 井冈山市|