久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

thinkPHP多表查詢及分頁功能實現方法示例

這篇文章主要介紹了thinkPHP多表查詢及分頁功能實現方法,結合具體實例形式分析了thinkPHP多表查詢以及查詢結果的分頁顯示相關實現技巧,需要的朋友可以參考下

本文實例講述了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程序設計有所幫助。

【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。

相關文檔推薦

這篇文章主要介紹了ThinkPHP實現轉換數據庫查詢結果數據到對應類型的方法,涉及thinkPHP模型類操作及針對源碼文件的相關修改方法,需要的朋友可以參考下
這篇文章主要介紹了thinkPHP中鉤子的使用方法,結合實例形式分析了thinkPHP鉤子的創建、添加、使用等相關操作技巧與注意事項,需要的朋友可以參考下
這篇文章主要介紹了thinkphp5.0驗證類的簡單有效的使用方法,一起學習下。
本文主要講了thinkphp5.0版本中自定義驗證規則的使用方法和一些注意事項。
這篇文章主要介紹了thinkPHP基于反射實現鉤子的方法,結合實例形式分析了php基于系統自帶的ReflectionClass、ReflectionMethod 類與函數實現鉤子功能的相關操作技巧,需要的朋友可以參考下
這篇文章主要介紹了thinkPHP通用控制器實現方法,結合實例形式分析了thinkPHP針對數據庫的基本CURD操作方法的封裝實現技巧,需要的朋友可以參考下
主站蜘蛛池模板: 亚洲狠狠爱一区二区三区 | 欧美一级二级三级视频 | 久久99国产精品 | 黑人精品欧美一区二区蜜桃 | 免费网站国产 | 涩涩片影院 | 国产精品网址 | 国产精品亚洲综合 | 国产69精品久久99不卡免费版 | 成人久久久 | 久久精品免费一区二区三 | 日韩一级电影免费观看 | 精品视频一区二区在线观看 | 国产乱精品一区二区三区 | 欧美一级视频在线观看 | 欧洲亚洲精品久久久久 | 99精品亚洲国产精品久久不卡 | 久久久久久免费毛片精品 | 日本中文字幕一区 | 亚洲精品视频在线 | 成人h免费观看视频 | 成人免费一区二区三区视频网站 | 亚洲三区在线 | 亚洲精品一区二区三区四区高清 | 国产色婷婷久久99精品91 | 国产一区二区三区四区 | 一区观看 | 一区二区国产精品 | 亚洲视频免费观看 | 国产一二三区在线 | 天天操夜夜操免费视频 | 婷婷综合 | 成人免费视频网站在线观看 | 久久高清精品 | 国产av毛片| 亚洲一区二区三区四区五区中文 | 在线激情视频 | 北条麻妃国产九九九精品小说 | 九九热最新地址 | 日韩精品在线播放 | 欧美一级黄色片免费观看 |