PHP+MySQL分页显示示例分析
时间:2009-04-02
来源:互联网
分页程序有两个非常重要的参数:每页显示几条记录($pagesize)和当前是第几页($page)。有了这两个参数就可以很方便的写出分页程序,我们以MySql数据库作为数据源,在mysql里如果要想取出表内某段特定内容可以使用的 T-SQL语句:select * from table limit offset,rows来实现。这里的offset是记录偏移量,它的计算方法是offset=$pagesize*($page-1),rows是要显示的记录条数,这里就是$page。也就是说select * from table limit 10,10这条语句的意思是取出表里从第11条记录开始的20条记录。
二、主要代码解析
$pagesize=10; //设置每一页显示的记录数
$conn=mysql_connect("localhost","root",""); //连接数据库
$rs=mysql_query("select count(*) from tb_product",$conn); //取得记录总数$rs
$myrow = mysql_fetch_array($rs);
$numrows=$myrow[0];
//计算总页数
$pages=intval($numrows/$pagesize);
//判断页数设置
if (isset($_GET[@#page@#])){
$page=intval($_GET[@#page@#]);
}
else{
$page=1; //否则,设置为第一页
}
三、创建用例用表myTable
create table myTable(id int NOT NULL auto_increment,news_title varchar(50),news_cont text,add_time datetime,PRIMARY KEY(id))
四、完整代码
<html>
<head>
<title>php分页示例</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>
<body>
<?php
$conn=mysql_connect("localhost","root","");
//设定每一页显示的记录数
$pagesize=1;
mysql_select_db("mydata",$conn);
//取得记录总数$rs,计算总页数用
$rs=mysql_query("select count(*) from tb_product",$conn);
$myrow = mysql_fetch_array($rs);
$numrows=$myrow[0];
//计算总页数
$pages=intval($numrows/$pagesize);
if ($numrows%$pagesize)
$pages++;
//设置页数
if (isset($_GET[@#page@#])){
$page=intval($_GET[@#page@#]);
}
else{
//设置为第一页
$page=1;
}
//计算记录偏移量
$offset=$pagesize*($page - 1);
//读取指定记录数
$rs=mysql_query("select * from myTable order by id desc limit $offset,$pagesize",$conn);
if ($myrow = mysql_fetch_array($rs))
{
$i=0;
?>
<table border="0" width="80%">
<tr>
<td width="50%" bgcolor="#E0E0E0">
<p align="center">标题</td>
<td width="50%" bgcolor="#E0E0E0">
<p align="center">发布时间</td>
</tr>
<?php
do {
$i++;
?>
<tr>
<td width="50%"><?=$myrow["news_title"]?></td>
<td width="50%"><?=$myrow["news_cont"]?></td>
</tr>
<?php
}
while ($myrow = mysql_fetch_array($rs));
echo "</table>";
}
echo "<div align=@#center@#>共有".$pages."页(".$page."/".$pages.")";
for ($i=1;$i< $page;$i++)
echo "<a href=@#fenye.php?page=".$i."@#>[".$i ."]</a> ";
echo "[".$page."]";
for ($i=$page+1;$i<=$pages;$i++)
echo "<a href=@#fenye.php?page=".$i."@#>[".$i ."]</a> ";
echo "</div>";
?>
</body>
</html>
五、总结
本例代码在windows2000 server+php4.4.0+mysql5.0.16上运行正常。该示例显示的分页格式是[1][2][3]…这样形式。假如想显示成“首页 上一页 下一页 尾页”这样形式,请加入以下代码:
$first=1;
$prev=$page-1;
$next=$page+1;
$last=$pages;
if ($page > 1)
{
echo "<a href=@#fenye.php?page=".$first."@#>首页</a> ";
echo "<a href=@#fenye.php?page=".$prev."@#>上一页</a> ";
}
if ($page < $pages)
{
echo "<a href=@#fenye.php?page=".$next."@#>下一页</a>
echo "<a href=@#fenye.php?page=".$last."@#>尾页</a> ";
}
其实,写分页显示代码是很简单的,只要掌握了它的工作原理。希望这篇文章能够带给那些需要这方面程序web程序员的帮助。
作者: showze 发布时间: 2009-04-02
作者: hongzh426 发布时间: 2009-04-02
if (isset($_GET[@#page@#])){
$page=intval($_GET[@#page@#]);
}
else{
$page=1; //否则,设置为第一页
}
里面的 @#是代表什么?
作者: 张鑫 发布时间: 2009-04-03
作者: 刘 伟 发布时间: 2009-04-03
作者: shuangyinlz 发布时间: 2009-04-03
作者: 黄何 发布时间: 2009-04-04
作者: 叶青 发布时间: 2009-05-19
作者: 孙洪涛 发布时间: 2009-05-19
作者: pen960 发布时间: 2009-05-21
只要引用就可以分页
作者: mylinux 发布时间: 2009-05-21
作者: ronglizx 发布时间: 2009-05-22
if (isset($_GET[@#page@#])){
$page=intval($_GET[@#page@#]);
}
else{
$page=1; //否则,设置为第一页
}
里面的 @#是代表什么?
张鑫 发表于 2009-4-3 11:15 =700) window.open('http://bbs.lampbrother.net/images/common/back.gif');" onload="if(this.offsetWidth>'700')this.width='700';if(this.offsetHeight>'700')this.height='700';" >
那是指你引用的url后面的后缀,比如说你前面的页面链接到当前页面是example.php?page=1, 那么你在写PHP的时候要判断是否后面有这个后缀page, 如果有才开始分页显示 如果没有就不显示, 楼主这样写可能是为了避免出现 注入漏洞, 我一般都直接 if(isset($_GET["page"])) 都一样的 如果你对安全性要求不高
作者: 李柯鹏 发布时间: 2009-05-23
作者: ttyyu 发布时间: 2009-06-17
作者: sy998 发布时间: 2009-06-25
if (isset($_GET[@#page@#])){
$page=intval($_GET[@#page@#]);
}
else{
$page=1; //否则,设置为第一页
}
里面的 @#是代表什么?
张鑫 发表于 2009-4-3 11:15 =700) window.open('http://bbs.lampbrother.net/images/common/back.gif');" onload="if(this.offsetWidth>'700')this.width='700';if(this.offsetHeight>'700')this.height='700';" >
应该是一个模板的作用
echo "<a href=@#fenye.php?page=".$first."@#>首页</a> ";
看这个每次改变页都会传回@# #@这个
作者: andy_bin 发布时间: 2009-06-28
作者: xiaotengjing 发布时间: 2009-06-30
作者: cyw113 发布时间: 2009-07-02
作者: 孙洪涛 发布时间: 2009-07-07
作者: 李振宇 发布时间: 2009-07-08

作者: ice723lee 发布时间: 2009-07-20
作者: changjl 发布时间: 2009-07-22
作者: mysky2012 发布时间: 2009-07-22
作者: mysky2012 发布时间: 2009-07-22
作者: jy02893849 发布时间: 2011-04-28
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28