[TOC]
## page方法
>[info] 其实limit 方法完全可以实现分页查询 ,但是page提供了一种更加人性化的体验
### 1、功能:为分页查询提供更加直观的实现方法
### 2、源码:/thinkphp/library/think/db/Query.php
~~~
/**
* 指定分页
* @access public
* @param mixed $page 页数
* @param mixed $listRows 每页数量
* @return $this
*/
public function page($page, $listRows = null)
{
if (is_null($listRows) && strpos($page, ',')) {
list($page, $listRows) = explode(',', $page);
}
$this->options['page'] = [intval($page), intval($listRows)];
return $this;
}
~~~
>[info] 看到源码是否觉得眼熟呢?对,与limit方法源码极其相似,区别在于给查询选择options[ 'page' ]赋值,limit是字符串,page是一个数组;
### 3、参数与返回值
* 参数很有意思,值得唠一唠
| 序号 | 参数 | 说明 |
| :---: | --- | --- |
| 1 | $page / 数字 / 字符串 | 根据公式计算出来的当前页数,公式后面介绍 |
| 2 | $listRows / 数字 / 字符串 | 每页显示的记录数量 |
* 返回值:仍然是当前查询对象本身。
### 4、实例演示
* 这里我们先以上节课学过的limit方法实现一下:
~~~
// 显示第一页数据
Db::table('tp5_staff') -> field('id,name,salary') -> limit(0,5) -> select();
// 显示第二页数据,只需要将起始位置由0,改为3即可
Db::table('tp5_staff') -> field('id,name,salary') -> limit(5,5) -> select();
// 以此类推,第三页
Db::table('tp5_staff') -> field('id,name,salary') -> limit(10,5) -> select();
~~~
>[success] 规律(计算公式):
>* limit参数中,变化是的起始位置$offset,查询数量是不变的$listRows;
>* $offset变化规律:(当前页码 - 1)* 每页显示数量 (这里假设为 5 )
> * 如第1页的起始位置:(1-1)* 5 = 0 ,即 : limit( 0, 5);
> * 第2页的起始位置:(2-1)* 5 =5,即:limit( 5, 5);
> * 第3页的起始位置:(3-1)* 5 =10 , 即:limit( 10,5 );
> * 以下页,就依此类推即可。
* 明白了分页规律后,用page方法可以大简化这种操作,将上例改写:
~~~
// 显示第一页数据
Db::table('tp5_staff') -> field('id,name,salary') -> page(1,5) -> select();
// 显示第二页数据,只需要将起始位置由0,改为3即可
Db::table('tp5_staff') -> field('id,name,salary') -> page(2,5) -> select();
// 以此类推,第三页
Db::table('tp5_staff') -> field('id,name,salary') -> page(3,5) -> select();
~~~
>[success] page方法中第一个参数是显示页数,第二个是显示数量,这样一来,代码显示整洁直观。
* page方法可以只有一个参数:页数,此时,需要与limit方法配合工作
~~~
// 显示第一页数据,page方法参数为1,后面跟上limit方法设置显示数量
Db::table('tp5_staff') -> field('id,name,salary') -> page( 1 ) -> limit( 5 ) -> select();
// 显示第二页数据,page方法参数为2,后面跟上limit方法设置显示数量
Db::table('tp5_staff') -> field('id,name,salary') -> page( 2 ) -> limit( 5 ) -> select();
// 以此类推,第三页
Db::table('tp5_staff') -> field('id,name,salary') -> page( 3 ) -> limit( 5 ) -> select();
~~~
>[info] 使用了page( 页数 ) -> limit( 数量 ) 语法,代码是不是更加的简洁、优雅了呢?
#### 任务1:以每页5条记录方法,显示前三页数据(tp5_staff表)
* Index.php 控制器代码如下:
~~~
<?php
namespace app\index\controller;
//导入数据库类
use think\Db;
class Index {
public function index(){
$result = Db::table('tp5_staff') // 设置数据表
-> field(['name' => '姓名','salary' => '工资']) // 设置显示的字段别名
-> page(2,5) //设置显示第二页,每页显示5条记录
->select(); //生成结果集
//查看结果
dump($result);
}
}
~~~
* 查询结果如下:
~~~
array(5) {
[0] => array(2) {
["姓名"] => string(9) "西门庆"
["工资"] => float(19801)
}
[1] => array(2) {
["姓名"] => string(9) "潘金莲"
["工资"] => float(8567)
}
[2] => array(2) {
["姓名"] => string(6) "宋江"
["工资"] => float(9261)
}
[3] => array(2) {
["姓名"] => string(9) "老顽童"
["工资"] => float(5000)
}
[4] => array(2) {
["姓名"] => string(9) "欧阳峰"
["工资"] => float(4900)
}
}
~~~
* 生成的SQL语句:
~~~
SELECT `name` AS `姓名`,`salary` AS `工资` FROM `tp5_staff` LIMIT 5,5
~~~
* 在SQLPRO FOR MySQL 中查看:
![](https://box.kancloud.cn/7b301eeb1edc3137e064b896bf0b47d6_1087x775.png)
### 4、总结:
>[info] 其实在开发,page方法用得较少,更多的是使用limit方法。但page方法仍需要知道其基本用法,因为我们会在读其它程序员的源码时会遇到。
- 前言[随时更新]
- ThinkPHP 5数据库重构
- 开发环境
- 1.ThinkPHP5开发环境(Mac版)
- 2.ThinkPHP5开发环境(Win版)
- MySQL快速复习
- 1.数据库操作
- 2.数据表操作
- 1.创建数据表 (重点)
- 2.添加数据表记录
- 3.查询数据表(重点)
- 4.更新数据表
- 5.编辑数据表结构(重点)
- 6_复制数据表
- 7.删除数据和表
- 连接数据库
- 1.数据库配置文件database.php
- 2.Db类静态方法connect()
- 3.模块中的配置文件config.php
- MySQL原生查询
- 1.读操作query
- 2.写操作execute
- 选择数据表
- 1.table与setTable方法
- 2.name方法
- 3.db助手函数
- 4.alias方法
- 结果集查询
- 1.find方法
- 2.select方法
- 3.fetchSql方法
- 4.value方法
- 5.column方法
- 6.field方法
- 新增数据
- 1.insert_单条添加
- 2.insertAll_批量添加
- 3_db_助手函数添加
- 更新数据
- 1.update方法
- 2.setField更新字段
- 3_自增自减与延时更新
- 删除数据
- 1.delete方法
- 查询方法
- 1.getTableInfo方法
- 2.where方法
- 3.whereOr方法
- 4.混合查询(闭包实现)
- 表达式查询
- 1.表达式查询(重点)
- 2.exp通用查询
- 分组查询
- 1.group方法
- 2.having方法
- 排序分页查询
- 1.order方法
- 2.limit方法
- 3.page方法
- 聚合查询
- 时间查询
- 1.where方法
- 2.whereTime方法
- 高级查询
- 1.快捷查询
- 2.区间查询
- 3.批量查询
- 4.Query对象查询
- 5.混合查询
- 视图查询
- view方法
- 子查询
- 1.select方法
- 2.fetchSql方法
- 3.buildSql方法
- 4.闭包子查询
- 总结/参考
- 1.方法参数类型总结
- 2.查询/子查询/连接查询