一、普通数据分页
ThinkPHP内置了分页实现,要给数据添加分页输出功能变得非常简单,可以直接在Db类查询的时候调用paginate方法:
// 查询状态为1的用户数据 并且每页显示10条数据
$list = Db::name('user')->where('status',1)->order('id', 'desc')->paginate(10);
// 渲染模板输出
return view('index', ['list' => $list]);
模板文件中分页输出代码如下:
<div> <ul> {volist name='list' id='user'} <li> {$user.nickname}</li> {/volist} </ul> </div> {$list|raw}
二、大数据分页
对于大量数据的分页查询,系统提供了一个高性能的paginateX分页查询方法,用法和paginate分页查询存在一定区别。如果你要分页查询的数据量在百万级以上,使用paginateX方法会有明显的提升,尤其是在分页数较大的情况下。并且由于针对大数据量而设计,该分页查询只能采用简洁分页模式,所以没有总数。
主要场景是针对主键进行分页查询,默认使用主键倒序查询分页数据。
$list = Db::name('user')->where('status',1)->paginateX(20);
也可以在查询的时候可以指定主键和排序
$list = Db::name('user')->where('status',1)->paginateX(20, 'id', 'desc');
查询方法会执行两次查询,第一次查询用于查找满足当前查询条件的最大或者最小值,然后配合主键查询条件来进行分页数据查询。
以上就是thinkphp6的分页介绍,更多请参考ThinkPHP6开发手册。
文章评论(0)