成人精品一区二区三区中文字幕-成人精品一区二区三区-成人精品一级毛片-成人精品亚洲-日本在线视频一区二区-日本在线视频免费

導航首頁 ? 技術教程 ? thinkPHP多表查詢及分頁功能實現方法示例
全站頭部文字 我要出現在這里
thinkPHP多表查詢及分頁功能實現方法示例 786 2024-01-10   

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

項目業務邏輯為:教師上傳試卷,設置答題卡,發布答題卡給相關的班級或群組,只有試卷關聯的答題卡發布后,該試卷才能在系統試卷中搜索到,同時其他的老師也可以收藏。在前端的收藏模塊中,有個業務是給個input框以提供搜索功能給用戶,但是在事先設計的搜索表中,只有一處試卷ID是和試卷表關聯的,如果用戶搜索試卷題目那豈不要兩表查詢了,一開始我想到的方法是在收藏表中多加個字段,也就是把試卷題目的字段添加到收藏表中,業務完成。今天在處理題庫分享的邏輯時,又發現了這個問題,看了下同事設計的分享表只有一個題庫ID,于是我便把同事叫過來“糾正”,但事先我還是想聽聽同事的設計思路,同事說量表查詢啊,我勒個去,看來我一張表查詢使用習慣了,沒有想到此種情況,被鄙視了,于是正視了自己的錯誤,當然了前提是說了下自己的思路,現在想來不怎么對,下面便給給出相關的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';
  // 總數
  $count = M()->table("$collect collect, $resource resource")->where($map)->count();
  // 總頁數
  $regNum = ceil($count/6);
  // 驗證當前請求頁碼是否大于總頁數
  $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相關內容感興趣的讀者可查看本站專題:《ThinkPHP入門教程》、《thinkPHP模板操作技巧總結》、《ThinkPHP常用方法總結》、《codeigniter入門教程》、《CI(CodeIgniter)框架進階教程》、《Zend FrameWork框架入門教程》及《PHP模板技術總結》。

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


PHP

主站蜘蛛池模板: 地下车库设计规范| 塔木德全文阅读免费| 电影《donselya》在线观看| 转正意见评语| 男女电视剧| 中国最贵的10大香烟| 鏖战鲁西南| 铁血使命电视剧演员表| 菊次郎的夏天钢琴曲谱| dj舞曲超劲爆dj| 平型关大捷纪念馆| 控制点电影| 肖叮叮的剿匪记 电视剧免费观看| 事业编面试题库及答案| 女生操女生| 飞天猪| 盛夏晚晴天演员表| 喜迎20大文艺汇演主持词| 女生操| 王若晰 个人资料| 战长沙每个人的结局| 探究事物的本质的读后感想| 欧美亚洲欧美| 搜狐视频官网| 都市频道在线直播观看| 《牵牛花》阅读答案| 池田夏希| porn21| 大奉打更人电视剧在线观看全集免费播放| 电影《武状元苏乞儿》| 时代少年团壁纸| 李诚洁| 老男孩之猛龙过江 电影| v我50图片| 战长沙剧情介绍| 红日歌词中文谐音歌词| 请假单| 中央五节目表| 控制点电影| 来不及说我爱你免费全集在线观看| 太原教育电视台|

?。?!站長長期在線接!??!

網站、小程序:定制開發/二次開發/仿制開發等

各種疑難雜癥解決/定制接口/定制采集等

站長微信:lxwl520520

站長QQ:1737366103