JavaShuo
栏目
标签
24-PHP+MySQL分页技术详解
时间 2020-07-19
标签
php+mysql
php
mysql
分页
技术
详解
栏目
PHP
繁體版
原文
原文链接
PHP+MySQL分页技术详解
今天,咱们来看一下PHP+MySQL的分页技术!首先,咱们先须要了解一下分页的原理是什么?
1、分页的原理
其实,分页的原理异常简单,其利用了MySQL的select语句的limit子句来实现的!
Limit子句的语法结构是:
limit offset,rowCount;
这两个参数的含义是记录的偏移值和每次显示的记录数,对于每次显示的记录数其实就是决定每页显示几条记录!这个值由开发者来任意决定,固然确定最小值要大于等于1。
咱们来研究一下offset参数,咱们先假设一种状况:记录无限多,而每页显示10条记录,咱们来推算一下吧!另外偏移值是从0开始计算的!
当前页 偏移值
1 0
2 10
3 20
4 30
…
n (n-1) * 10
那么这就是偏移值的计算公式:
(当前页码 – 1 ) * 每页显示的记录数
因此limit参数的使用就变成了
limit (当前页码 – 1 ) * 每页显示的记录数,每页显示的记录数
另外,有的朋友可能问了,若是最后一页不足10条那怎么办呢?若是最后一页不足10条,则将显示剩余的所有记录,也就是说若是总记录数为63条记录;每页显示10条记录,那么第7页只显示3条记录!
2、分页的过程
若是想实现分页的过程,那么必须通过如下几步:
1. 获取总记录数
2. 指定每页显示的记录数
3. 根据1和2来计算出总页数
4. 分页显示记录
好了,咱们一步一步的来实现!
1. 获取总记录数
$sql = “select * from test”;
$result = mysql_query($sql);
$rowsNum = mysql_num_rows($result);
mysql_free_result($result);
2. 指定每页显示的记录数
$pageSize = 2;
其实这句话从纯粹的PHP角度来说就是给变量赋值!
3. 获取总页数
$pageCount = ceil($rowsNum / $pageSize);
好了,最起码到这里为止,咱们能够来显示页码了!
<?php
$conn = @mysql_connect("localhost","root","ccjsj") || die("服务器链接错误");
@mysql_select_db("test") || die("指定数据库不存在");
$sql = "select * from test";
$result = mysql_query($sql) ;
$rowsNum = mysql_num_rows($result);
$pageSize = 2;
$pageCount = ceil($rowsNum / $pageSize);
?>
<body>
<table width="850" border="0" cellpadding="5" cellspacing="1" bgcolor="#666666">
<?php if($rowsNum) {?>
<tr>
<td bgcolor="#FFFFFF">编号</td>
<td bgcolor="#FFFFFF">用户名</td>
</tr>
<tr>
<td bgcolor="#FFFFFF"> </td>
<td bgcolor="#FFFFFF"> </td>
</tr>
<tr>
<td colspan="2" bgcolor="#FFFFFF">
<?php
if($rowsNum <= $pageSize)
{
echo "1";
}
else
{
for($i=1;$i<=$pageCount;$i++)
echo "{$i} ";
}
?>
</td>
</tr>
<?php } else { ?>
<tr>
<td bgcolor="#FFFFFF">对不起,数据表中不存在符合条件的记录!</td>
</tr>
<?php }?>
</table>
运行结果以下:
好了,先显示记录内容吧!
<?php
...
...
?>
<body>
<table width="850" border="0" cellpadding="5" cellspacing="1" bgcolor="#666666">
<?php if($rowsNum) {?>
<tr>
<td bgcolor="#FFFFFF">编号</td>
<td bgcolor="#FFFFFF">用户名</td>
</tr>
<?php while($row = mysql_fetch_array($result)){ ?>
<tr>
<td bgcolor="#FFFFFF"><?=$row['id']?></td>
<td bgcolor="#FFFFFF"><?=$row['name']?></td>
</tr>
<?php } ?>
<tr>
<td colspan="2" bgcolor="#FFFFFF">
<?php
if($rowsNum <= $pageSize)
{
echo "1";
}
else
{
for($i=1;$i<=$pageCount;$i++)
echo "{$i} ";
}
?>
</td>
</tr>
<?php } else { ?>
<tr>
<td bgcolor="#FFFFFF">对不起,数据表中不存在符合条件的记录!</td>
</tr>
<?php }?>
</table>
但运行结果以下:
为何结果会是这样呢?
缘由就是在咱们如今的结果集是select * from test来的,而应该是select * from test limit X,Y来得到的!那么,怎么才能够获得咱们指望的结果集呢,那就要来研究一下页码了!由于,咱们在前面已经推算过了,因此,咱们只要知道用户单击的那个连接,那么就能够根据前面推算的公式来计算偏移值了!
那么怎么知道用户单击的那个连接呢?若是将页码传递给本身那不就能够了吗!好了,就这么干吧!
<?php
$conn = @mysql_connect("localhost","root","ccjsj") || die("服务器链接错误");
@mysql_select_db("test") || die("指定数据库不存在");
$sql = "select * from test";
$result = mysql_query($sql) ;
$rowsNum = mysql_num_rows($result);
$pageSize = 2;
$pageCount = ceil($rowsNum / $pageSize);
$pageno = $_GET["pageno"];
$offset = ($pageno -1) * $pageSize;
$sql .= " limit {$offset},{$pageSize}";
$result = mysql_query($sql);
?>
<body>
<table width="850" border="0" cellpadding="5" cellspacing="1" bgcolor="#666666">
<?php if($rowsNum) {?>
<tr>
<td bgcolor="#FFFFFF">编号</td>
<td bgcolor="#FFFFFF">用户名</td>
</tr>
<?php while($row = mysql_fetch_array($result)){ ?>
<tr>
<td bgcolor="#FFFFFF"><?=$row['id']?></td>
<td bgcolor="#FFFFFF"><?=$row['name']?></td>
</tr>
<?php } ?>
<tr>
<td colspan="2" bgcolor="#FFFFFF">
<?php
if($rowsNum <= $pageSize)
{
echo "1";
}
else
{
for($i=1;$i<=$pageCount;$i++)
echo "<a href=\"{$_SERVER['PHP_SELF']}?pageno={$i}\">{$i}</a> ";
}
?>
</td>
</tr>
<?php } else { ?>
<tr>
<td bgcolor="#FFFFFF">对不起,数据表中不存在符合条件的记录!</td>
</tr>
<?php }?>
</table>
运行结果以下:
怎么会错了呢!仔细一下,原来问题在$_GET[“pageno”],在用户刚刚访问该页码时,用户没有单击任何的连接,那么$_GET[‘pageno’]的返回值就是空,而空-1则等于-1,那么偏移值则等于-1*2,那就成了-2了,因此才会报错的!那么只要将初始的页码改变1就能够了!
if ($pageno == "") $pageno = 1;
运行结果以下:
好了,今天的话题就先到这儿,其实,这个东西还存在一些bug和不足,咱们慢慢来升级吧!
各位晚安!
相关文章
1.
java分页技术实现详解
2.
分页技术
3.
web分页技术
4.
PHP 分页技术
5.
分页技术--sql语句的分页
6.
JQuery技术详解
7.
LOD技术详解
8.
CDN技术详解
9.
RAID技术详解
10.
JNI技术详解
更多相关文章...
•
XML 相关技术
-
XML 教程
•
Hibernate的快照技术
-
Hibernate教程
•
三篇文章了解 TiDB 技术内幕——说存储
•
三篇文章了解 TiDB 技术内幕 —— 说计算
相关标签/搜索
CDN技术详解
分步详解
技术解析
技术分享
技术分析
详解
分页
注解详解
技术
技术美术
PHP
MySQL
Spring教程
MyBatis教程
Redis教程
技术内幕
0
分享到微博
分享到微信
分享到QQ
每日一句
每一个你不满意的现在,都有一个你没有努力的曾经。
最新文章
1.
部署Hadoop(3.3.0)伪分布式集群
2.
从0开始搭建hadoop伪分布式集群(三:Zookeeper)
3.
centos7 vmware 搭建集群
4.
jsp的page指令
5.
Sql Server 2008R2 安装教程
6.
python:模块导入import问题总结
7.
Java控制修饰符,子类与父类,组合重载覆盖等问题
8.
(实测)Discuz修改论坛最后发表的帖子的链接为静态地址
9.
java参数传递时,究竟传递的是什么
10.
Linux---文件查看(4)
本站公众号
欢迎关注本站公众号,获取更多信息
相关文章
1.
java分页技术实现详解
2.
分页技术
3.
web分页技术
4.
PHP 分页技术
5.
分页技术--sql语句的分页
6.
JQuery技术详解
7.
LOD技术详解
8.
CDN技术详解
9.
RAID技术详解
10.
JNI技术详解
>>更多相关文章<<