搜索
首页后端开发php教程分页原理技术细节剖析(php+mysql)实例

提到分页,大家都不陌生,在我们日常浏览网页时常遇到,尤其新闻文章列表等都有分页,如下图所示:

分页实例

下面,通过一个实例为大家剖析一下分页原理上技术细节。

一、功能开发思路

在分页功能的实现前,先做了一个思维导图理清一下大概的思路,废话不多说,上图:

分页原理思维导图

二、功能开发各模块介绍

用到的工具有,轻量级编辑器editplus,mysql数据库管理工具phpmyadmin,环境为windows 7下Apache+PHP+Mysql。下面,给大家分享一下,运用php、mysql如何实现如上分页效果。

1.mysql数据库的创建准备

在设计这个功能时,创建了一个数据库"fenye",表名为"people",设定了字段——序号(id,为主键,自增),姓名(name),性别(sex),如下图:

数据库"fenye"结构图

2.php功能实现介绍

php功能页面,设计了三个——公共调用页conn.php,添加信息页add.php,信息列表页list.php。下面来做各功能页面的技术细节分析。

(1).公共调用页conn.php

该功能页面主要实现数据库及表的连接,数据库编码的设定,代码如下:

<?php@mysql_connect("localhost:3306","数据库用户名","数据库密码")or die("mysql连接失败");      //mysql连接@mysql_select_db("fenye")or die("db连接失败");         //数据库"fenye"连接mysql_query("set names gbk");      //数据库编码设置为gbk?>

注解

  • @ 符号用于屏蔽因mysql连接失败时报错显示的mysql信息,出于用户体验和安全性考虑;
  • die()函数:用于mysql数据库连接失败时抛出错误提示信息,其中内容自定义。
(2).添加信息页add.php

该功能页面主要向数据库内添加信息记录,核心功能代码为插入sql语句,完整代码如下:

<?phpinclude("conn.php");      //调用conn.phpif(!empty($_POST["subs"])){      //判断subs数据是否提交  $user=$_POST["user"];        //将表单提交上来的姓名user赋值给$user  $sex=$_POST["sex"];      //将表单提交上来的性别sex赋值给$sex  $sql="insert into `people` (`id`,`name`,`sex`) values (null,'$user','$sex')";      //插入sql语句  echo mysql_query($sql) ? "<script language='javascript'>alert('插入成功');</script>" : mysql_error(); //三元判断语句,执行成功返回js脚本提示信息,不成功抛出错误提示mysql_error()  }?><div class="nav"><a href="add.php">添加信息</a></div><div class="main">    <form action="add.php" method="post">        姓名:<input type="text" name="user" /><br/><br/>        性别:<input type="text" name="sex" /><br/><br/>        <input type="submit" name="subs" value="保存"/>    </form></div>

注解

  • 三元判断语句:条件 ? 结果1 : 结果2——成功执行结果1,失败执行结果2
  • mysql_error()函数用于返回上一个mysql操作产生的文本错误信息提示

(3)信息列表页list.php

该页主要功能用于呈现信息列表,并实现分页功能,先上完整代码,如下:

<div class="nav">  <a href="add.php">添加信息</a></div><div class="main">  <table cellspacing="0" cellpadding="10" border="1" bordercolor="#cccccc" />    <tr><td>序号</th><th>姓名</th><th>性别</th></tr><?phpinclude("conn.php");      //调用conn.php页面$pagesize=5;               //设定每页记录显示5条$url=$_SERVER["REQUEST_URI"];      //获取当前文件完整url,赋值给$url$url=parse_url($url);        //将当前$url按照组成部分转换为数组,赋值给$url$url=$url[path];      //获取当前$url的路径,赋值给$url$numq=mysql_query("select * from `people`");      //查询表`people`内所有记录,赋值给$numq$num=mysql_num_rows($numq);      //获取$numq的总条数,赋值给$numif($_GET["page"]){      //判断当前页参数'page'是否存在,存在执行以下代码  $pageval=$_GET["page"];      //将参数'page'赋值给$pageval  $page=($pageval-1)*$pagesize;      //执行分页公式,将值赋值给起始值$page  $page.=",";      //连接字符','}if(is_integer($num/$pagesize)){      //判断总页码是否为整数,若为整数执行以下代码  $sumpage=$num/$pagesize;      }else{  $sumpage=intval($num/$pagesize)+1;      //总页码不为整数,取整然后+1}for($i=1;$i<=$sumpage;$i++){      //循环打印页码  if($i==$pageval){       //当前页码不加超链接    $pagenum.=$i." ";  }else{    $pagenum.="<a href=$url?page=".$i.">".$i."</a> ";  }}if($num>$pagesize){      //若总条数大于每页记录显示条数,执行以下分页代码   if($pageval<=1){        //当传递过来的参数'page'小于等于1时(即避免页码出现0或负值)     $pageval=1;     echo "共 $num 条 ".$pagenum."<a href=$url?page=".($pageval+1).">下一页</a> <a href=$url?page=".$sumpage.">末页</a>";  }else if((($num/$pagesize)-$pageval)<=0){      //总页码(不一定为整数)与当前页码的差小于等于0时,即最后一页,执行以下代码    echo "共 $num 条 <a href=$url?page=1>首页</a> <a href=$url?page=".($pageval-1).">上一页</a>".$pagenum;  }else{      //其他情况,即页码非第一页或最后一页,执行以下代码    echo "共 $num 条 <a href=$url?page=1>首页</a> <a href=$url?page=".($pageval-1).">上一页</a>".$pagenum."<a href=$url?page=".($pageval+1).">下一页</a> <a href=$url?page=".$sumpage.">末页</a>";  }}$sql="select * from `people` limit $page $pagesize";      //依照limit条件查询记录,赋值$sql为查询语句$query=mysql_query($sql);      //执行代码while($rs=mysql_fetch_array($query)){      //循环将每条记录以数组形式存入$rs?><tr>    <td><?php echo $rs["id"] ?></td>    <td><?php echo $rs["name"] ?></td>    <td><?php echo $rs["sex"] ?></td></tr><?php}?></table></div>

由于代码篇幅较长,下面根据功能实现的思路进行细节剖析:首先,找到功能实现的核心基础,页码分页核心代码:select * from `表名` limit 起始值,读取条数;即:

$sql="select * from `people` limit $page $pagesize";

需要设定两个变量,起始值$page,读取条数$pagesize$pagesize可人为赋值,起始值$page的获取则要费一番周折,需要用到分页公式:起始值=(当前页面-1)* 每页显示条数,因为我们需要关联到当前的页码$pageval,因此得到如下代码:

if($_GET["page"]){    $pageval=$_GET["page"];    $page=($pageval-1)*$pagesize;    $page.=",";}

获取$page后,我们还要实现首页、上一页、下一页、末页、页码罗列、记录总条数的功能,记录总条数相对简单,直接查询所有记录条数$num即可,即:

$numq=mysql_query("select * from `people`");$num=mysql_num_rows($numq);

至于首页、上一页、下一页、末页、页码罗列这些,则需要运用在超链接设置对应的参数'?page='来实现,如:

格式:<a href=$url?page=".对应页码.">目标页</a>

所以$url对应页码是需要想办法获取的。首先我们来看$url的获取,要用到两个函数:$_SERVER["REQUEST_URI"](用于获取完整的URL)、parse_url()(将url按照组成部分分类后,以数组形式存放),然后取出路径path,即:

$url=$_SERVER["REQUEST_URI"];$url=parse_url($url);$url=$url[path];

$url获取后,我们来看一下对应页码的获取,首页的参数获取最简单,直接'page=1'即可,上一页、下一页分别为($pageval-1),($pageval+1)末页则为'page=总页码',即$sumpage。此处,首页、末页以及中间页需要进行条件判断:

  • 首页:当前页$pageval小于等于1时;
  • 末页:当$num(总条数)与$pagesize(每页显示条数)的商与当前页面$pageval的差值小于等于0(即两者之商小于或等于当前页值)时;
  • 中间页:除以上情况。即
if($num>$pagesize){    if($pagesize<=1){      //首页      $pagesize=1;      echo "共 $num 页 ".$pagenum."<a href=$url?page=".($pageval+1).">下一页</a> <a href=$url?page=".$sumpage.">末页</a>";    }else if((($num/$pagesize)-$pageval)<=0){      //末页      echo "共 $num 页 <a href=$url?page=1>首页</a> <a href=$url?page=".($pageval-1).">上一页</a>".$pagenum;    }else{      //中间页      echo "共 $num 页 <a href=$url?page=1>首页</a> <a href=$url?page=".($pageval-1).">上一页</a>".$pagenum."<a href=$url?page=".($pageval+1).">下一页</a> <a href=$url?page=".$sumpage.">末页</a>";    }}

其中末页'page=$sumpage'的取值需两种情况:当$num(总条数)与$pagesize(每页显示条数)的商为整数时,$sumpage=$sum/$pagesize;当两者之商不为整数时,则$sumpage=intval($sum/$pagesize)+1。即

if(is_integer($sum/$pagesize)){    $sumpage=$sum/$pagesize;}else{    $sumpage=($sum/$pagesize)+1;}

最后,$pagenum(页码罗列)需要从第一页到最后一页依次打印,所以,此处运用for循环,并进行条件判断:当处于当前页码时,即$i==$pageval,不加超链接;除此之外,加超链接,即:

for($i=1;$i<=$sumpage;$++){    if($i==$pageval){      $pagenum.=$i." ";    }else{      $pagenum.="<a href=$url?page=".$i.">".$i."</a>";    }}

自此,整个分页功能的各个功能代码段一一剖析出来,在此代码基础上,稍加修改和调整样式,即可实现常见实用的分页功能。

(4)总结

其实,对于每一位PHP学习者来说,打好基础都是非常重要的,可以使我们在以后的学习中避免重复犯错,影响学习进度和深度,这里推荐大家多通读几遍PHP:PHP manual,此外推荐大家一个PHP的REPL:PsySH,供实验调试PHP代码,在此祝大家加油,玩转PHP!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
简单地说明PHP会话的概念。简单地说明PHP会话的概念。Apr 26, 2025 am 12:09 AM

phpsessionstrackuserdataacrossmultiplepagerequestsusingauniqueIdStoredInacookie.here'showtomanageThemeffectionaly:1)startAsessionWithSessionwwithSession_start()和stordoredAtain $ _session.2)

您如何循环中存储在PHP会话中的所有值?您如何循环中存储在PHP会话中的所有值?Apr 26, 2025 am 12:06 AM

在PHP中,遍历会话数据可以通过以下步骤实现:1.使用session_start()启动会话。2.通过foreach循环遍历$_SESSION数组中的所有键值对。3.处理复杂数据结构时,使用is_array()或is_object()函数,并用print_r()输出详细信息。4.优化遍历时,可采用分页处理,避免一次性处理大量数据。这将帮助你在实际项目中更有效地管理和使用PHP会话数据。

说明如何使用会话进行用户身份验证。说明如何使用会话进行用户身份验证。Apr 26, 2025 am 12:04 AM

会话通过服务器端的状态管理机制实现用户认证。1)会话创建并生成唯一ID,2)ID通过cookies传递,3)服务器存储并通过ID访问会话数据,4)实现用户认证和状态管理,提升应用安全性和用户体验。

举一个如何在PHP会话中存储用户名的示例。举一个如何在PHP会话中存储用户名的示例。Apr 26, 2025 am 12:03 AM

Tostoreauser'snameinaPHPsession,startthesessionwithsession_start(),thenassignthenameto$_SESSION['username'].1)Usesession_start()toinitializethesession.2)Assigntheuser'snameto$_SESSION['username'].Thisallowsyoutoaccessthenameacrossmultiplepages,enhanc

哪些常见问题会导致PHP会话失败?哪些常见问题会导致PHP会话失败?Apr 25, 2025 am 12:16 AM

PHPSession失效的原因包括配置错误、Cookie问题和Session过期。1.配置错误:检查并设置正确的session.save_path。2.Cookie问题:确保Cookie设置正确。3.Session过期:调整session.gc_maxlifetime值以延长会话时间。

您如何在PHP中调试与会话相关的问题?您如何在PHP中调试与会话相关的问题?Apr 25, 2025 am 12:12 AM

在PHP中调试会话问题的方法包括:1.检查会话是否正确启动;2.验证会话ID的传递;3.检查会话数据的存储和读取;4.查看服务器配置。通过输出会话ID和数据、查看会话文件内容等方法,可以有效诊断和解决会话相关的问题。

如果session_start()被多次调用会发生什么?如果session_start()被多次调用会发生什么?Apr 25, 2025 am 12:06 AM

多次调用session_start()会导致警告信息和可能的数据覆盖。1)PHP会发出警告,提示session已启动。2)可能导致session数据意外覆盖。3)使用session_status()检查session状态,避免重复调用。

您如何在PHP中配置会话寿命?您如何在PHP中配置会话寿命?Apr 25, 2025 am 12:05 AM

在PHP中配置会话生命周期可以通过设置session.gc_maxlifetime和session.cookie_lifetime来实现。1)session.gc_maxlifetime控制服务器端会话数据的存活时间,2)session.cookie_lifetime控制客户端cookie的生命周期,设置为0时cookie在浏览器关闭时过期。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

VSCode Windows 64位 下载

VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

WebStorm Mac版

WebStorm Mac版

好用的JavaScript开发工具