php中数据分页显示 php中分页功能的实现

PHP显示很多数据库信息 , 如何自动分页呢?代码PHP代码如下:
/*
Author:默默
Date :2006-12-03
*/
$page=isset($_GET['page'])?intval($_GET['page']):1; //这句就是获取page=18中的page的值,假如不存在page,那么页数就是1 。
$num=10; //每页显示10条数据
$db=mysql_connect("host","name","pass"); //创建数据库连接
$select=mysql_select_db("db",$db); //选择要操作的数据库
/*
首先咱们要获取数据库中到底有多少数据,才能判断具体要分多少页,具体的公式就是
总数据数除以每页显示的条数,有余进一 。
也就是说10/3=3.3333=4 有余数就要进一 。
*/
$total=mysql_num_rows(mysql_query("select id from table")); //查询数据的总数,id是数据库中的一个自动赋值的字段
$pagenum=ceil($total/$num); //获得总页数
//假如传入的页数参数大于总页数 , 则显示错误信息
If($page$pagenum || $page == 0){
Echo "Error : Can Not Found The page .";
Exit;
}
$offset=($page-1)*$num; //获取limit的第一个参数的值 , 假如第一页则为(1-1)*10=0,第二页为(2-1)*10=10 。
$info=mysql_query("select name from table limit $offset,$num"); //获取相应页数所需要显示的数据,name是数据里的一个字段
While($it=mysql_fetch_array($info)){
Echo $it['name']."
";
} //显示数据
For($i=1;$i=$pagenum;$i){
$show=($i!=$page)?"$i":"$i";
Echo $show." ";
}
/*显示分页信息 , 假如是当页则显示粗体的数字,其余的页数则为超连接,假如当前为第三页则显示如下
1 2 3 4 5 6
*/
?
PHP如何实现分页显示?【文件名】: c_mysql_page.inc // 【作 用】: MySQL分页函数类 // 【作 者】: 天灰 // // 【最后修改日期】: 2001/07/16[cxx] // 【变量定义规则】:‘C_’=字符型,‘I_’=整型,‘N_’=数字型,‘L_’=布尔型,‘A_’=数组型 //------------------------------------------------------------------------------------------ //------------------------------------------------------------------------------------------ // ※c_mysql_page() 构造函数,设置分页初始参数 // ※page_standard() 分页显示函数(标准型) // ※GetRecordStartEnd() 获得取记录的开始结束位置 // ※getmaxpage() 获得记录集的最大页数 // ※checkpage() 检查当前页数是否在0和最大页数之间 //------------------------------------------------------------------------------------------ class c_mysql_page { //------------------------------------------------------------------------------------------ // 变量定义 //------------------------------------------------------------------------------------------ var $I_pagesize = 10; //每页记录数 var $C_width = '80%'; //表格宽度 //------------------------------------------------------------------------------------------ //------------------------------------------------------------------------------------------ // 函数名:c_mysql_page ($I_pagesize, $c_width) // 作 用:构造函数,设置分页初始参数 // 参 数:$I_pagesize, $c_width // 返回值:变量 // 备 注:构造函数随着类的建立而自动执行 //------------------------------------------------------------------------------------------ function c_mysql_page ($I_pagesize=10, $C_width='80%') { if (isset($I_pagesize)){$this - I_pagesize = $I_pagesize;} if (isset($C_width)){$this - C_width = $C_width;} } //------------------------------------------------------------------------------------------ // 函数名:page_standard($I_sumrecord,$C_page,$C_url="self",$C_otherpara="") // 作 用:分页显示函数(标准型) // 参 数:$I_sumrecord 记录总数 // $C_url URL // $C_page URL后的参数 // $C_otherpara URL后的参数2 // $bgcolor 表格的背景颜色 // 返回值: // 备 注:无 //------------------------------------------------------------------------------------------ function page_standard($I_sumrecord,$C_page,$C_url="self",$C_otherpara="",$bgcolor="") { //检查参数 if ((!$I_sumrecord) || (!$C_page)){AlertExit("参数不全!");} global $PHP_SELF,$$C_page; //全局变量$C_page //检测$I_pagesize是否合法 if($this - I_pagesize1){AlertExit("请设定每页的记录数!");} if($I_sumrecord1){return false;} //检测总记录数 if($C_url == "self"){$C_url = $PHP_SELF;} //设置URL $I_page = $$C_page; //重新赋当前页值 $I_maxpage = $this - getmaxpage($I_sumrecord); //取出总页数 $I_page = $this - checkPage($I_maxpage,$I_page); //检查当前页号 //显示表 echo ""; echo ""; echo "共" . $I_sumrecord. "条主题nbsp当前第" . $I_page . "/". $I_maxpage. "页"; if ($I_maxpage1) { echo ""; if($I_page1$I_page$I_maxpage) { echo "首页"; $pre=$I_page-1; echo "上页"; $next=$I_page 1; echo "下页"; echo "末页"; } elseif($I_page == 1) { $next = $I_page 1; echo "下页"; echo "末页"; } elseif($I_page == $I_maxpage) { echo "首页"; $pre=$I_page-1; echo "上页"; } //显示select echo "转到"; echo "";//OnChange=".WindowLocation($C_url,$C_otherpara,$C_page)." for($i=1;$iI_pagesize; $I_pagesize = $this - I_pagesize; } //------------------------------------------------------------------------------------------ //------------------------------------------------------------------------------------------ // 函数名:getmaxpage($intRecordNum) // 作 用:获得记录集的最大页数 // 参 数:$I_sumrecord 记录总数 // 返回值:最大页数$I_maxpage(整型) // 备 注:无 //------------------------------------------------------------------------------------------ function getmaxpage($I_sumrecord) { if (!$I_sumrecord){AlertExit("参数不全!
php 数组分页显示这句的算法就不正确了 。if(!isset($arr_click[($page - 1) * $size$i]))break;
这句改成 if(!isset($arr_click[$i]))break;当第三页的时候 $i 已经是从索引6开始了,你原来的句子却是 (3-1)*3 6 肯定 超出索引了啦 。
我想你的第二页数据,虽然显示了,肯定与索引不对,第二页按你的搞法 , 应该是显示的索引6开始的 。第一页显示的 应该是索引为3开始的 。
还有
if(isset($_GET['page'])){
$page = intval($_GET['page']);
$page = $page$pnum? $pnum: $page;
}else{
$page = 1;
}
$page = empty($_GET['page']) ? '1' : $_GET['page'];
这段代码,if 里面已经有page了 。后面还要再获取一次page干嘛呢 。
望采纳啦 。有什么问题可以百度HI我 。
php分页显示?
$sql="select * from table ";//查表
$res=mysql_query($sql);//取得结果
$nums=mysql_num_rows($res);//取得总记录数
$pagesize=15;//设定每页的记录数
$pages=ceil($nums/$pagesize);//取得总页数
if($pages1){$pages=1;}//设定总页数至少1页
$page=$_GET[page];//取得传递过来的页数
if($page$pages){$page=$pages;}//如果传递过来的页数比总页数还大 , 就让它等于总页数
if($page1){$page=1;}//如果传递过来的页数小于1,就让他等于1
$kaishi=($page-1)*$pagesize;//为下一步做准备,limit的初始记录
$sql="select * from table order by id desc limit $kaishi,$pagesize";//取得记录从计算出的初始值开始 , 一共$pagesize条
$res=mysql_query($sql);//取得结果
while($arr=mysql_fetch_array($res))
{
echo $arr[id]."---".$arr[biaoti].'br';//输出记录的ID和标题
}
?
下面是分页br /
a href="https://www.04ip.com/post/?page=1"首页/a a href="https://www.04ip.com/post/?page=? echo $page-1;?"上页/a 当前第? echo $page;?页 a href="https://www.04ip.com/post/?page=? echo $page 1;?"下页/a a href="https://www.04ip.com/post/?page=? echo $pages;?"尾页/a
【php中数据分页显示 php中分页功能的实现】php中数据分页显示的介绍就聊到这里吧 , 感谢你花时间阅读本站内容,更多关于php中分页功能的实现、php中数据分页显示的信息别忘了在本站进行查找喔 。

    推荐阅读