本文摘自PHP中文网,作者coldplay.xixi,侵删。

一、连接数据库
1 | $connect = mysqli_connect( 'localhost' , '用户名' , '密码' , '数据库名' ) or die ( '数据库连接失败' );mysqli_set_charset( $connect , 'utf8' );
|
相关免费学习推荐:mysql视频教程
二、构建SQL语句
分页其实利用的是MySQL
中limit
关键字来实现的,例如我们查询一个表中的前两条数据:
1 | select * from student limit 0, 2
|
limit
后需要两个参数,第一个参数代表从第几条开始取;第二个参数代表一次取几条。
那么上述SQL
语句表达的意思为从第 0 条开始取,取 2 条(实则 0 为第 1 条,计数从 0 开始)。
我们把取到的前两条数据作为第一页。
那么继续取第二页,还是 2 条数据,则SQL
语句为:
1 | select * from student limit 2, 2
|
第三页:
1 | select * from student limit 4, 2
|
以此类推,我们发现每页始终是两条,所以limit
的第二个参数(即 2)已经确定好了,那么第一个参数该如何确定呢?其实其中的规律如下:
第 1 页:0,2 (第 1 页从 0 的位置取,取 2 条,即 0 1 )
第 2 页:2,2 (第 2 页从 2 的位置取,取 2 条,即 2 3 )
第 3 页:4,2 (第 3 页从 4 的位置取,取 2 条,即 4 5 )
第 4 页:6,2 (第 4 页从 6 的位置取,取 2 条,即 6 7 )
……
所以每页的起始位置 = (当前页 - 1) * 每页显示的条数
第 1 页:(1 - 1) * 2 = 0
第 2 页:(2 - 1) * 2 = 2
第 3 页:(3 - 1) * 2 = 4
……
三、定义每页显示的条数
四、定义当前页
五、根据公式计算limit
需要的第一个参数
1 | $start = ( $page - 1) * $pageSize ;
|
所以SQL语句为:
1 | select * from student limit $start , $pageSize ;
|
这时改变$page
的值,就可以查询对应页的数据。
六、通过地址栏传参得到$page
参数来定义当前页
为了更加的灵活我们通过地址栏传参得到想要显示的页数,所以第四步的代码改为:
1 2 3 | if ( $_GET [ 'page' ]) {
$page = $_GET [ 'page' ];} else {
$page = 1;
|
七、通过按钮控制上下页切换
将SQL
语句执行:
1 | $sql = "select * from student limit $start, $pageSize" ; $query = mysqli_query( $connect , $sql ); $result = mysqli_fetch_all( $query , MYSQLI_ASSOC);
|
将结果输出到HTML
表格:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | <table border= "1" cellspacing= "0" cellpadding= "0" style= "width: 50%;text-align: center;" >
<caption>学生列表</caption>
<tr>
<td>ID</td>
<td>姓名</td>
<td>年龄</td>
<td>性别</td>
<td>手机号</td>
</tr>
<?php foreach ( $result as $v ) { ?>
<tr>
<td><?php echo $v [ 'id' ]; ?></td>
<td><?php echo $v [ 'name' ]; ?></td>
<td><?php echo $v [ 'age' ]; ?></td>
<td><?php echo $v [ 'sex' ]; ?></td>
<td><?php echo $v [ 'mobile' ]; ?></td>
</tr>
<?php } ?></table>
|
增加上下页按钮:
1 | <button>上一页</button><button>下一页</button>
|
当点击上一页
,我们需要给当前页$page - 1
;
当点击下一页
,我们需要给当前页$page + 1
;
在当前页的基础上确定上一页:
假设当前页为第 2 页,那么$up
则为 2 - 1 = 1,即上一页是第 1 页。
在当前页的基础上确定下一页:
假设当前页为第 2 页,那么$next
则为 2 + 1 = 3,即下一页是第 3 页。
所以我们给按钮加一个超链接,链接到当前页,并携带一个page
参数,值为相应的页数。
1 | <a href= "form-7.php?page=<?php echo $up; ?>" ><button>上一页</button></a><a href= "form-7.php?page=<?php echo $next; ?>" ><button>下一页</button></a>
|
但是$up
和$next
并不是无限加减的,当已经是第一页的时候,$up
不可再继续减,所以在确定上一页的时候需要加一个判断。
1 2 3 | if ( $page == 1) {
$up = 1;} else {
$up = $page - 1;}
|
同理,确定下一页的时候也需要判断,什么时候不可以继续下一页了呢?当当前页已经是最后一页的时候不可继续下一页,最后一页如何判定,取决于当前表的总条数,当前表如果有 10 条数据,每页显示 2 条,那么需要分 10 / 2 = 5 页,这个 5 就是最后一页,如果有 11 条数据,那么需要分 11 / 2 = 5.5 页,说明分 5 页还剩下 1 条,所以直接分 6 页,即向上取整,那么这个 6 就是最后一页。
求出总条数:
1 | $sql = "select * from student" ; $query = mysqli_query( $connect , $sql ); $num = mysqli_num_rows( $query );
|
根据总条数
和每页显示的条数
求出需要分几页:
1 | $totalPage = ceil ( $num / $pageSize );
|
所以在判断下一页的时候改为:
1 2 3 | if ( $page == $totalPage ) {
$next = $totalPage ;} else {
$next = $page + 1; }
|
八、完整代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 | <?php
$page = $_GET [ 'page' ];} else {
$page = 1;}
$up = 1;} else {
$up = $page - 1;}
$next = $totalPage ;} else {
$next = $page + 1; }
<head>
<meta charset= "UTF-8" >
<meta name= "Generator" content= "EditPlus?" >
<meta name= "Author" content= "" >
<meta name= "Keywords" content= "" >
<meta name= "Description" content= "" >
<title>Document</title>
</head>
<body>
<table border= "1" cellspacing= "0" cellpadding= "0" style= "width: 50%;text-align: center;" >
<caption>学生列表</caption>
<tr>
<td>ID</td>
<td>姓名</td>
<td>年龄</td>
<td>性别</td>
<td>手机号</td>
</tr>
<?php foreach ( $result as $v ) { ?>
<tr>
<td><?php echo $v [ 'id' ]; ?></td>
<td><?php echo $v [ 'name' ]; ?></td>
<td><?php echo $v [ 'age' ]; ?></td>
<td><?php echo $v [ 'sex' ]; ?></td>
<td><?php echo $v [ 'mobile' ]; ?></td>
</tr>
<?php } ?>
</table>
<a href= "form-7.php?page=<?php echo $up; ?>" ><button>上一页</button></a>
<a href= "form-7.php?page=<?php echo $next; ?>" ><button>下一页</button></a>
</body></html>
|
相关免费学习推荐:mysql数据库(视频)
以上就是介绍PHP + MySQL 实现数据分页显示的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
教你直接从mysql中将数据打印到文件中
mysql索引是什么?mysql索引的相关知识介绍
mysql深度分页(千万级数据量如何快速分页)
如何使用mysql表连接
【mysql数据库】第四章解读:schema与数据类型优化(上)
linux centos mysql数据库安装配置实例分享
mysql不等于符号怎么写
mysql如何插入多条数据?
mysql如何进行解压式安装
开发过程中mysql常见问题的解决方法
更多相关阅读请进入《PHP》频道 >>
机械工业出版社
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。
转载请注明出处:木庄网络博客 » 介绍PHP + MySQL 实现数据分页显示