利用page计算分页

$p=input('p')?input('p'):1;
$limit=6;
$res=db('points_log')->where(['p_uid'=>$uid,'del_id'=>0])->field('p_log_id,p_uid,integral_source,integral,creat_time')->page($p,$limit)->order('creat_time desc')->select();

$count=db('points_log')->where(['p_uid'=>$uid,'del_id'=>0])->count();

//计算分页总数
$page=ceil($count/$limit);

var_dump($page);

第二种 limit计算分页

        $list_rows= $data['list_rows'] ? $data['list_rows'] : 10;
        $page= $data['page'] > 0 ? $data['page'] : 1;
        $result = NavModel::where(['typeid' => $data['typeid'], 'status' => 1])
      //因为要从传默认是1 这个需要减1
                    ->limit(($page-1)*$list_rows,$list_rows)
                    ->select()->toArray();
        if (count($result) >= 1) {
            foreach ($result as &$v) {
                if ($v['thumb']) {
                    $v['thumb'] = get_file_url($v['thumb']);
                }
                $v = $this->filter($v, $this->fname);
            }
            return ApiReturn::r(1, $result, '请求成功');
        }

thinkphp 使用  paginate 计算分页

$config = [
'list_rows' => $data['list_rows'] ? $data['list_rows'] : 10,
'page' => $data['page'] > 0 ? $data['page'] : 1
];
$list = $commentModle
->where($where)
->paginate($config)//分页数自己确定
->each(
function($item){
        //存入数据到name里面
$item['name']= Db::name('community_comment')->where(['pid' => $item['id']])->limit(5)->select();
    require  $item;
        }
);

如果这个需要传值
$config = [
'list_rows' => $data['list_rows'] ? $data['list_rows'] : 10,
'page' => $data['page'] > 0 ? $data['page'] : 1
];
$a=1;
$list = $commentModle
->where($where)
->paginate($config)//分页数自己确定
->each(
function($item,$a){
        //存入数据到name里面
$item['name']= Db::name('community_comment')->where(['pid' => $item['id']])->limit(5)->select();
    require  $item;
        }
);

或者

$config = [
'list_rows' => $data['list_rows'] ? $data['list_rows'] : 10,
'page' => $data['page'] > 0 ? $data['page'] : 1
];
$a=1;
$list = $commentModle
->where($where)
->paginate($config)//分页数自己确定
->each(
function($item)use($a){
        //存入数据到name里面
$item['name']= Db::name('community_comment')->where(['pid' => $item['id']])->limit(5)->select();
    require  $item;
        }
);


另外一种方式
$config = [
'list_rows' => $data['list_rows'] ? $data['list_rows'] : 10,
'page' => $data['page'] > 0 ? $data['page'] : 1
];
$list = $commentModle
->where($where)
->paginate($config)//分页数自己确定
->each(
function($item,$key){
        //存入数据到name里面
$item['name']= Db::name('community_comment')->where(['pid' => $item['id']])->limit(5)->select();
        }
);

如果pageinate 这个方法从不能接收使用
在pageinate
就可以使用all();这个方法赋值但是分页就要重新赋值了如下

$res = $list->all();
   foreach ($res as $k => $v){
  if($v['agent_id'] == $v['adviser_id']){
   $res[$k]['user_nickname'] = "";
   }else{
   if(($user_type == 1) && ($v['agent_id'])){
     $res[$k]['agent_name'] = Db::name('user')->where('id',$v['agent_id'])->value('user_name');
    }
   if(($user_type == 2) && ($v['adviser_id'])){
      $res[$k]['adviser_name'] = Db::name('user')->where('id',$v['adviser_id'])->value('user_name');
         }
       }
     $res[$k]['user_img']=get_file_url(411);

}
  $return_list['data'] = $res; 数据
  $return_list['total'] = Db::name('user_customer')->where($whereid)->where($whereproduct)->where($wheresearch)->where($whereimportance)->count();多少条数据
  $return_list['per_page'] = $config['list_rows'];分页显示数量
  $return_list['current_page'] = $config['page'];分页
  $return_list['last_page'] = ceil($return_list['total']/$return_list['per_page']);分页数量


还有一种方法
     /*
因为数据列表刷新的时候
例如: 有11条数据 如果我请求第二页的时候 会删除一条数据之后第二页会请求不到 就要以以id为进行分页
* */
$id=input('id')?input('id'):1;
$limit=10;
$res=db('points_log')
->where("id","<",$id)
->field('p_log_id,p_uid,integral_source,integral,creat_time')
->limit($limit)
->order('creat_time desc')
->select();

$count=db('points_log')->where(['p_uid'=>$uid,'del_id'=>0])->count();

//计算分页总数
$page=ceil($count/$limit);


thinkphphp 计算分页 和分页总数 和sql计算分页 php的更多相关文章

  1. sql语句分页多种方式

    sql语句分页多种方式ROW_NUMBER()OVER sql语句分页多种方式ROW_NUMBER()OVER 2009年12月04日 星期五 14:36 方式一 select top @pageSi ...

  2. SQL server分页的四种方法(算很全面了)

      这篇博客讲的是SQL server的分页方法,用的SQL server 2012版本.下面都用pageIndex表示页数,pageSize表示一页包含的记录.并且下面涉及到具体例子的,设定查询第2 ...

  3. SQL存储过程分页(通用的拼接SQL语句思路实现)

    多表通用的SQL存储过程分页 案例一: USE [Community] GO /****** Object: StoredProcedure [dbo].[Common_PageList] Scrip ...

  4. sql语句分页多种方式ROW_NUMBER()OVER

    sql语句分页多种方式ROW_NUMBER()OVER 摘自: http://www.cnblogs.com/CodingArt/articles/1692468.html 方式一 select to ...

  5. Oracle基础(五)pl/sql进阶(分页过程)

    编写分页过程         通过pl/sql实现分页过程,再该过程中由简单到难一步步深入,目的在于通过该案例熟悉pl/sql的各种存储过程,包,游标.怎样在java中调用等内容的学习. 1.无返回值 ...

  6. oracle count 百万级 分页查询记要总数、总条数优化

    oracle count 百万级 分页查询记录总数.总条数优化 oracle count 百万级 查询记录总数.总条数优化 最近做一个项目时,做分页时,发现分页查询速度很慢,分页我做的是两次查询,一次 ...

  7. SQL Server游标 C# DataTable.Select() 筛选数据 什么是SQL游标? SQL Server数据类型转换方法 LinQ是什么? SQL Server 分页方法汇总

    SQL Server游标   转载自:http://www.cnblogs.com/knowledgesea/p/3699851.html. 什么是游标 结果集,结果集就是select查询之后返回的所 ...

  8. SQL server分页的四种方法

    SQL server分页的四种方法 1.三重循环: 2.利用max(主键); 3.利用row_number关键字: 4.offset/fetch next关键字 方法一:三重循环思路  先取前20页, ...

  9. Windows分页文件设置不当导致SQL Server服务被终止

    Windows分页文件设置不当导致SQL Server服务被终止 文章说明 在正式开始验证和测试之前,先介绍Windows分页文件和SQL Server的动态内存管理.下面测试将分为两种测试场景:场景 ...

  10. SQL server分页的三种方法

    一.Entity Framework的Linq语句的分页写法: var datacount = test.OrderBy(t => t.testID) .Skip(pageSize * (pag ...

随机推荐

  1. not in 和 not exists 比较和用法

    尽量不要使用not in(它会调用子查询),而尽量使用not exists(它会调用关联子查询).查询语句使用了not in,那么对内外表都进行全表扫描,没有用到索引:而not exists的子查询依 ...

  2. 安全、高效!天翼云HPFS助企业一臂之力!

    近年来,随着各行业数智转型逐步深入以及人工智能大模型的蓬勃发展,气象分析.大模型训练.自动驾驶.石油勘探.EDA仿真.基因分析等高性能计算(HPC)场景和智算场景(AI)不仅对算力需求激增,也产生了图 ...

  3. 四柱汉诺塔的 Frame-Stewart 算法及其最优性

    注:本文基本上是对参考文献 \(1\) 的翻译.这份论文是法语的,并且我没找到英语版本或中文介绍( 大家应该很熟悉汉诺塔了把,,,这里就不解释三柱汉诺塔了. Frame-Stewart 算法 对于有 ...

  4. 【ABP】项目示例(1)——项目搭建前置准备

    项目介绍 本项目使用.NET8+ABP+MySql搭建,基于DDD的设计思想,创建分层Web应用程序. 相关文档 .NET开发文档 Entity Framework Core开发文档 ABP开发文档 ...

  5. Django setting可以配置什么?

    Setting配置信息 注册子应用 # 注意:需要修改Django的全局配置文`settings.py`'''1. 创建子应用 1)在pycharm中创建 python manage.py start ...

  6. 割以咏志:Stoer–Wagner 算法求解全局最小割

    全局最小割问题(Global Min-Cut Problem)是图论中的一个经典问题,旨在通过切割图中的边来划分图的顶点集合.具体来说,给定一个加权无向图 $ G = (V, E) $,图中每条边 $ ...

  7. AI如何改变数据驱动决策的方式

    导语 在这个信息爆炸的时代,数据成为了企业和组织最为宝贵的资源.然而,单纯的数据堆积并没有太大价值,只有通过分析和挖掘,才能真正发挥数据的潜力.随着AI技术的飞速发展,我们正见证着数据驱动决策方式发生 ...

  8. 莫托曼机器人GP110B操作手柄故障维修全攻略

     莫托曼机器人GP110B操作手柄故障机器人维修全攻略              一.前言              莫托曼机器人GP110B操作手柄是机器人控制系统的重要组成部分,它允许操作人员对机 ...

  9. K230学习记录

    K230学习记录 参考自: # 立创·庐山派-K230-CanMV开发板资料与相关扩展板软硬件资料官网全部开源 # 开发板官网:www.lckfb.com # 技术支持常驻论坛,任何技术问题欢迎随时交 ...

  10. Flink - [07] 容错机制

    题记部分 一.一致性检查点   Flink故障恢复机制的核心,就是应用状态的一致性检查点.有状态流应用的一致性检查点,其实就是所有任务的状态,在某个时间点的一份拷贝(一份快照):这个时间点,应该是所有 ...