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

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

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

本文實例講述了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相關內(nèi)容感興趣的讀者可查看本站專題:《ThinkPHP入門教程》、《thinkPHP模板操作技巧總結(jié)》、《ThinkPHP常用方法總結(jié)》、《codeigniter入門教程》、《CI(CodeIgniter)框架進階教程》、《Zend FrameWork框架入門教程》及《PHP模板技術總結(jié)》。

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

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

相關文檔推薦

這篇文章主要介紹了ThinkPHP實現(xiàn)轉(zhuǎn)換數(shù)據(jù)庫查詢結(jié)果數(shù)據(jù)到對應類型的方法,涉及thinkPHP模型類操作及針對源碼文件的相關修改方法,需要的朋友可以參考下
這篇文章主要介紹了thinkPHP中鉤子的使用方法,結(jié)合實例形式分析了thinkPHP鉤子的創(chuàng)建、添加、使用等相關操作技巧與注意事項,需要的朋友可以參考下
這篇文章主要介紹了thinkphp5.0驗證類的簡單有效的使用方法,一起學習下。
本文主要講了thinkphp5.0版本中自定義驗證規(guī)則的使用方法和一些注意事項。
這篇文章主要介紹了thinkPHP基于反射實現(xiàn)鉤子的方法,結(jié)合實例形式分析了php基于系統(tǒng)自帶的ReflectionClass、ReflectionMethod 類與函數(shù)實現(xiàn)鉤子功能的相關操作技巧,需要的朋友可以參考下
這篇文章主要介紹了thinkPHP通用控制器實現(xiàn)方法,結(jié)合實例形式分析了thinkPHP針對數(shù)據(jù)庫的基本CURD操作方法的封裝實現(xiàn)技巧,需要的朋友可以參考下
主站蜘蛛池模板: 91一区二区三区在线观看 | 亚洲成人自拍 | 久久久久国产精品一区三寸 | 亚洲精品久久久 | 亚洲欧美综合精品久久成人 | 亚洲一区二区三区在线播放 | 久热精品在线播放 | www狠狠爱com| 久久久网| 自拍偷拍在线视频 | 在线看片国产精品 | 91麻豆精品国产91久久久久久久久 | 国产一区二区影院 | 91在线导航 | 中文字幕 在线观看 | 九九色综合 | 狠狠操狠狠干 | www.五月婷婷.com | 国产成人精品久久二区二区91 | 一区二区三区视频在线观看 | 久久成人人人人精品欧 | 国产亚洲网站 | 尤物在线 | 久久国产精品一区二区 | 精品国产欧美一区二区三区成人 | 亚洲夜夜爽| 韩日一区二区三区 | 精品久久一区 | 高清成人av| 日韩在线精品视频 | 亚洲精品www| 成人区精品一区二区婷婷 | 男人天堂网址 | 一区二区不卡视频 | 亚洲图片视频一区 | 国产精品福利在线 | 色橹橹欧美在线观看视频高清 | 久久只有精品 | 天堂一区| a级大片 | 亚洲小视频 |