> 백엔드 개발 > PHP 튜토리얼 > thinkPHP의 통계 순위 및 페이징 표시 기능

thinkPHP의 통계 순위 및 페이징 표시 기능

不言
풀어 주다: 2023-03-30 14:10:01
원래의
3688명이 탐색했습니다.

이 글에서는 thinkPHP의 통계 순위 및 페이징 표시 기능을 주로 소개하고, thinkPHP 데이터베이스 쿼리 및 결과 페이징 표시와 관련된 조작 스킬을 예시 형태로 분석하여 도움이 필요한 친구들이 참고할 수 있습니다

이 글에서는 통계 순위를 분석합니다. thinkPHP의 페이징 표시 기능과 예제. 참조용으로 모든 사람과 공유하세요. 세부 사항은 다음과 같습니다.

count총 개수firstRow시작 행listRows모든 것을 얻으세요 time 레코드 수 list각 페이지의 레코드(개수와 일치해야 함)2 페이징 개체

는 실제 데이터 테이블에 대한 것일 수 있습니다. 통계 데이터 테이블일 수도 있고, 가상 테이블이 될 수도 있고

그룹 연산, 서브 쿼리를 수행하더라도 LIMIT가 마지막에 실행되기 때문입니다


html

<include file="Public:head" title="" />
<style type="text/css">
.top {
  font-size: 18px;
  border-bottom: #ddd 1px solid;
  margin-bottom: -1px;
  font-weight: bold;
}
.top .title {
  margin:10px;
  border:1px solid #EF6C00;
  display:-webkit-box;
  border-radius: 3px;
}
.top .title .title_child {
  width: 50%;
  line-height:40px;
  -webkit-box-flex:1;
  display:block;
  color:#EF6C00;
  text-decoration:none;
}
.top .title .title_child.active {
  color:#FFF;
  background:#EF6C00;
}
.page{
  margin-right: 10px;
}
.ranknum{
  font-weight: bold;
  color:#F92672;
}
#myrank{
  color: #FFF;
  font-weight:bold;
  background-color: #FBC853;
}
</style>
<script type="text/javascript">
</script>
<body>
<p class="top text-center">
  <p class="title">
    <a class="title_child <if condition=&#39;$type neq 1&#39;>active</if>" href="{sh::U(&#39;User/ranklist&#39;, array(&#39;type&#39; => 0))}">月排行</a>
    <a class="title_child <if condition=&#39;$type eq 1&#39;>active</if>" href="{sh::U(&#39;User/ranklist&#39;, array(&#39;type&#39; => 1))}">总排行</a>
  </p>
</p>
<p id="myrank" class="alert alert-danger text-center">
  我的商户数:{sh:$my_user_count}    当前排名: {sh:$my_rank}
</p>
<p id="datalist">
<table class="table table-hover">
   <thead>
    <tr>
     <th>  #</th>
     <th>姓名</th>
     <th>商户数</th>
    </tr>
   </thead>
   <tbody>
     <volist name="list" id="vo">
    <tr>
     <th scope="row" class="ranknum">
     <if condition="$vo.rank eq 1"><img src="{sh::RES}public/img/gold.png" style="width: 30px;">
     <elseif condition="$vo.rank eq 2"/><img src="{sh::RES}public/img/silver.png" style="width: 30px;">
     <elseif condition="$vo.rank eq 3"/><img src="{sh::RES}public/img/copper.png" style="width: 30px;">
     <else />
       {sh:$vo.rank}
     </if>
     </th>
     <td>{sh:$vo.name}</td>
     <td>{sh:$vo.usercount}</td>
    </tr>
    </volist>
   </tbody>
</table>
<p class="page text-right">
    {sh:$page}
</p>
</p>
</body>
</html>
로그인 후 복사

php

// 排行榜
public function ranklist(){
    $type = $this->_get(&#39;type&#39;,&#39;trim&#39;);
    $this->assign(&#39;type&#39;,$type);
    $opener_id = $this->opener_id;
    if($type == 0){ // 上月排行
      $arrLastMonth = $this->getLastMonthStartEndDay();
      $lastStartDay = $arrLastMonth[&#39;lastStartDay&#39;];
      $lastEndDay = $arrLastMonth[&#39;lastEndDay&#39;].&#39; 23:59:59&#39;; 
      $b_time = strtotime($lastStartDay);
      $e_time = strtotime($lastEndDay);
      $where[&#39;b.addtime&#39;] = array(array(&#39;gt&#39;,$b_time),array(&#39;lt&#39;,$e_time),&#39;and&#39;); 
    }
    $where[&#39;a.status&#39;] = array(&#39;eq&#39;,&#39;1&#39;);
    M()->query(&#39;SET @rank =0;&#39;);
    $subQuery = M()->table(&#39;sh_opener a&#39;)->join(&#39;sh_user b on a.id = b.opener_id&#39;)->where($where)->group(&#39;a.id&#39;)->order(&#39;usercount desc&#39;)->field(&#39;a.id,count(b.id) as usercount,a.name&#39;)->select(false);
    $all = M()->table(&#39;&#39;.$subQuery.&#39; a&#39;)->getField(&#39;a.id,a.usercount,a.name,(@rank:=IFNULL(@rank,0)+1) as rank&#39;);
    $count   = count($all);
    $Page    = new Page($count, 10);
    $list    = M()->table(&#39;sh_opener a&#39;)->join(&#39;sh_user b on a.id = b.opener_id&#39;)->where($where)->group(&#39;a.id&#39;)->order(&#39;usercount desc&#39;)->limit($Page->firstRow.&#39;,&#39;.$Page->listRows)->field(&#39;count(b.id) as usercount,a.name,a.id&#39;)->select();
    foreach ($list as $k => $v) {
      $list[$k][&#39;rank&#39;] = $k + 1 + $Page->firstRow;
    }
    // 我的商户
    $my_user_count = $all[$opener_id][&#39;usercount&#39;]?$all[$opener_id][&#39;usercount&#39;]:0;
    $my_rank = $all[$opener_id][&#39;rank&#39;]?$all[$opener_id][&#39;rank&#39;]:&#39;-&#39;;
    $this->assign(&#39;my_user_count&#39;,$my_user_count);
    $this->assign(&#39;my_rank&#39;,$my_rank);
    $this->assign(&#39;page&#39;,$Page->show());
    $this->assign(&#39;list&#39;, $list);
    $this->display();
}
// 获取上一月开始与结束日期
private function getLastMonthStartEndDay(){
    $thismonth = date(&#39;m&#39;);
    $thisyear = date(&#39;Y&#39;);
    if ($thismonth == 1) {
      $lastmonth = 12;
      $lastyear = $thisyear - 1;
    } else {
      $lastmonth = $thismonth - 1;
      $lastyear = $thisyear;
    }
    $lastStartDay = $lastyear . &#39;-&#39; . $lastmonth . &#39;-1&#39;;
    $lastEndDay  = $lastyear . &#39;-&#39; . $lastmonth . &#39;-&#39; . date(&#39;t&#39;, strtotime($lastStartDay)); //t 给定月份所应有的天数,28到31
    return array(&#39;lastStartDay&#39;=>$lastStartDay,&#39;lastEndDay&#39;=>$lastEndDay);
}
로그인 후 복사

thinkphp의 페이징 클래스 구현이 여기서 사용됩니다.

Case Effect

위 내용은 모두의 학습에 도움이 되기를 바랍니다. 더 많은 관련 내용은 PHP 중국어 홈페이지를 주목해주세요!

관련 추천:

thinkphp는 페이징 표시 기능을 구현합니다.


ThinkPHP의 총 기부 통계는 오락용일 뿐입니다. 너무 심각해지지 마세요

위 내용은 thinkPHP의 통계 순위 및 페이징 표시 기능의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿