thinkphp5 数据库查询之paginate: 同时获取记录总数和分页数据
thinkphp5中要想同时获得查询记录的总数量以及分页的数据, 可以用paginate(), 真的非常方便!
表结构:
CREATE TABLE `t_users` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
`email` varchar(128) COLLATE utf8mb4_bin NOT NULL DEFAULT '' COMMENT '登录账号',
`passwd` varchar(128) COLLATE utf8mb4_bin NOT NULL DEFAULT '',
`nickname` varchar(64) COLLATE utf8mb4_bin DEFAULT NULL COMMENT '昵称',
`company` varchar(256) COLLATE utf8mb4_bin DEFAULT NULL COMMENT '公司',
`contact` varchar(64) COLLATE utf8mb4_bin DEFAULT NULL COMMENT '联系人',
`address` varchar(256) COLLATE utf8mb4_bin DEFAULT NULL COMMENT '详细地址',
`city` varchar(64) COLLATE utf8mb4_bin DEFAULT NULL COMMENT '城市',
`country` varchar(128) COLLATE utf8mb4_bin DEFAULT NULL COMMENT '国家',
`province` varchar(64) COLLATE utf8mb4_bin DEFAULT NULL COMMENT '省/州',
`zip_code` varchar(64) COLLATE utf8mb4_bin DEFAULT NULL COMMENT '邮政编码',
`phone` varchar(64) COLLATE utf8mb4_bin DEFAULT NULL COMMENT '电话',
`token` varchar(128) COLLATE utf8mb4_bin DEFAULT NULL COMMENT '登录唯一凭证, 登录时更新',
`check` tinyint(1) DEFAULT '0' COMMENT '0-未通过, 1-通过',
`check_time` timestamp NULL DEFAULT NULL COMMENT '审核时间',
`time` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
PRIMARY KEY (`id`),
UNIQUE KEY `email` (`email`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin COMMENT='注册用户表';
表数据截图:

获取记录总数和分页数据:
public function test()
{
$r = db(self::TABLE)->paginate(3, false);
// $r = model(self::TABLE)->paginate(3, false);
print_r($r); $data = [
'total' => $r->total(), // 总记录数
'cur' => $r->currentPage(), // 当前页码
'size' => $r->listRows(), // 每页记录数
'list' => $r->items() // 分页数据
]; print_r($data);
}
截图:

最终运行结果:
cmf\paginator\Bootstrap Object
(
[simple:protected] =>
[items:protected] => think\Collection Object
(
[items:protected] => Array
(
[0] => Array
(
[id] => 1
[email] => 1@163.com
[passwd] => e10adc3949ba59abbe56e057f20f883e
[nickname] =>
[company] =>
[contact] =>
[address] =>
[city] =>
[country] => United Kingdom
[province] =>
[zip_code] =>
[phone] =>
[token] => ae4e61fa4ec3b7fc144603e4ca8e1f83
[check] => 1
[check_time] => 2019-08-21 22:23:16
[time] => 2019-08-19 10:25:18
) [1] => Array
(
[id] => 4
[email] => 1121@163.com
[passwd] => e10adc3949ba59abbe56e057f20f883e
[nickname] =>
[company] =>
[contact] =>
[address] =>
[city] =>
[country] => 日本
[province] =>
[zip_code] =>
[phone] =>
[token] => f1267ace3614544c7eda97e8b831f5ac
[check] => 1
[check_time] =>
[time] => 2019-08-19 12:32:25
) [2] => Array
(
[id] => 7
[email] => 1112312@163.com
[passwd] => e10adc3949ba59abbe56e057f20f883e
[nickname] =>
[company] =>
[contact] =>
[address] =>
[city] =>
[country] => 日本
[province] =>
[zip_code] =>
[phone] =>
[token] => ae0ffcc37d1f6f564e6045892f04a5ea
[check] => 0
[check_time] =>
[time] => 2019-08-19 16:43:13
) ) ) [currentPage:protected] => 1
[lastPage:protected] => 2
[total:protected] => 6
[listRows:protected] => 3
[hasMore:protected] => 1
[options:protected] => Array
(
[var_page] => page
[path] => /admin/users/test
[query] => Array
(
) [fragment] =>
[type] => \cmf\paginator\Bootstrap
[list_rows] => 15
) )
Array
(
[total] => 6
[cur] => 1
[size] => 3
[list] => Array
(
[0] => Array
(
[id] => 1
[email] => 1@163.com
[passwd] => e10adc3949ba59abbe56e057f20f883e
[nickname] =>
[company] =>
[contact] =>
[address] =>
[city] =>
[country] => United Kingdom
[province] =>
[zip_code] =>
[phone] =>
[token] => ae4e61fa4ec3b7fc144603e4ca8e1f83
[check] => 1
[check_time] => 2019-08-21 22:23:16
[time] => 2019-08-19 10:25:18
) [1] => Array
(
[id] => 4
[email] => 1121@163.com
[passwd] => e10adc3949ba59abbe56e057f20f883e
[nickname] =>
[company] =>
[contact] =>
[address] =>
[city] =>
[country] => 日本
[province] =>
[zip_code] =>
[phone] =>
[token] => f1267ace3614544c7eda97e8b831f5ac
[check] => 1
[check_time] =>
[time] => 2019-08-19 12:32:25
) [2] => Array
(
[id] => 7
[email] => 1112312@163.com
[passwd] => e10adc3949ba59abbe56e057f20f883e
[nickname] =>
[company] =>
[contact] =>
[address] =>
[city] =>
[country] => 日本
[province] =>
[zip_code] =>
[phone] =>
[token] => ae0ffcc37d1f6f564e6045892f04a5ea
[check] => 0
[check_time] =>
[time] => 2019-08-19 16:43:13
) ) )
===============================================
另外, paginate中第3个参数里可以配置请求的页码, 即请求指定页数据, 示例如下:
public function test()
{
$r = db(self::TABLE)->alias('a')
->join('users_good b', 'b.uid = a.id')
->field('uid, a.check,b.chinese,b.math')
->paginate(3, false, [
'page' => 2 // 指定请求的页码
]);
print_r($r); $data = [
'total' => $r->total(), // 总记录数
'cur' => $r->currentPage(), // 当前页码
'size' => $r->listRows(), // 每页记录数
'list' => $r->items() // 分页数据
]; print_r($data);
}
thinkphp5 数据库查询之paginate: 同时获取记录总数和分页数据的更多相关文章
- ObjectStore onFetch方法获取记录总数
转自:http://blog.csdn.net/earthhour/article/details/38686029 ObjectStore onFetch方法获取记录总数 require(['doj ...
- MySQL高效获取记录总数
通常mysql获取查询记录总数我们使用如下语句: SELECT COUNT(*) FROM users WHERE k='avs'; 或:SELECT id FROM goods WHERE k=' ...
- 【Mysql】MySQL高效获取记录总数SQL_CALC_FOUND_ROWS
用法说明 分页程序一般由两条SQL组成: SELECT COUNT(*) FROM ... WHERE .... SELECT ... FROM ... WHERE LIMIT ... 如果使用SQL ...
- SQL语句分组获取记录的第一条数据的方法
使用Northwind 数据库 首先查询Employees表 查询结果: city列里面只有5个城市 使用ROW_NUMBER() OVER(PARTITION BY COL1 ORDER BY CO ...
- PHP MYSQL 获取记录总数
$qid = mysql_query(“SELECT count(aid) as total FROM table group by aid “);//你的查询 $res = mysql_fetch_ ...
- 使用rowid和rownum获取记录时要注意的问题
我们知道.rowid和rownum在Oracle中都是能够被当做伪劣使用的,主要用来定位表中特定的记录,但它们是有差别的,rowid是和行记录的物理地址相应的.而rownum则不是,是通过返回的记录集 ...
- [转载]Hibernate如何提升数据库查询的性能
目录(?)[-] 数据库查询性能的提升也是涉及到开发中的各个阶段在开发中选用正确的查询方法无疑是最基础也最简单的 SQL语句的优化 使用正确的查询方法 使用正确的抓取策略 Hibernate的性能优化 ...
- dedeCMS php标签使用说明和数据库查询说明
1.{dede:php}标签想要输出信息 可以直接使用printf , echo,var_dump 之类的打印出来 赋值给@me 无效 2.结合sql语句使用方法 例:{dede:php} $ro ...
- jsp执行数据库查询并分页
需求: 有一批企业的基本信息需要展示出来,要求一级页以列表形式展示企业清单,点击公司名称后进入二级页面,二级页面展示企业简介和几张图片. 实现效果: 开发环境: Win7,Eclipse,Mysql ...
随机推荐
- AQS源码的简单理解
概念 AQS全称 AbstractQueuedSynchronizer. AQS是一个并发包的基础组件,用来实现各种锁,各种同步组件的.它包含了state变量.加锁线程.等待队列等并发中的核心组件. ...
- [Gamma]阶段发布说明
小小易校园微信小程序发布说明 第二版小小易校园小程序发布啦~ 打开微信,点击右上角➕,选择扫一扫,扫描以下二维码即可进入小程序: 版本功能: 上一版功能请参见[Beta阶段]发布说明. 当前版本的更新 ...
- 使用stunnle加密传输
Stunnel是一个可以用SSL对任意 TCP 连接加密的程序.它可以运行在多种UNIX和Windows上,它是基于 OpenSSL的,所以它要求已经安装了 OpenSSL,并进行了正确的配置.——来 ...
- A Philosophy of Software Design
关于复杂性,尚无统一的定义,从不同的角度可以给出不同的答案.可以用数量来度量,比如芯片集成的电子器件越多越复杂(不一定对):按层次性[2]度量,复杂度在于层次的递归性和不可分解性.在信息论中,使用熵来 ...
- 以前写的canvas 小游戏 贪吃蛇代码
效果如图,完成了贪吃蛇的基本的功能 代码地址 :https://github.com/my-new-git-hub/canvasSnake.git 预览地址:https://www.kzc275.to ...
- [转帖]分布式锁-redLock And Redisson
分布式锁-redLock And Redisson 2019-03-01 16:51:48 淹不死的水 阅读数 372更多 分类专栏: 分布式锁 版权声明:本文为博主原创文章,遵循CC 4.0 B ...
- 【Python + Selenium3】自动化测试之DDT数据驱动并生成测试报告以及用yagmail邮件发送文件
我的文件路径 一.DDT代码: import unittest from time import sleep from selenium import webdriver from ddt impor ...
- [Atcoder ARC103D]Robot Arms
题目大意:平面上有$n$个点,要求你构造$m$条边(满足$m\leqslant40$),使得可以从原点到达给定的$n$个点(边必须平行于坐标轴).并要求输出每一条边的方向,每条边必须都使用,无解输出$ ...
- Java学习:Debug调试程序
Debug追踪 Debug调试程序: 可以让代码逐行执行,查看代码执行的过程,调试程序中出现的bug 使用方式: 在行号的右边,鼠标左键单击,添加断点(每个方法的第一行,哪里有bug添加到哪里) 右键 ...
- JDK9版本以上Java独有的一个轻量级小工具,你知道吗?jshell
jshell,是JavaJDK9这个大版本更新以来,带来的一个轻量级小工具.我们再也不用进入Java目录,编写一个Java文件,然后再去编译,最后才能执行它. 这里,你可以直接写一个小功能,就能去实现 ...