PHP分页初探 一个最简单的PHP分页代码的简单实现

PHP分页代码在各种程序开发中都是必须要用到的,在网站开发中更是必选的一项。

要想写出分页代码,首先你要理解SQL查询语句:select * from goods limit 2,7。PHP分页代码核心就是围绕这条语句展开的,SQL语句说明:查询goods数据表从第2条数据开始取出7条数据。在分页代码中,7表示每页显示多少条内容,2通过公式计算表示翻页数,通过传入不同参数替换“2”的值,即可筛选出不同的数据。

index.php:

?


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

include ‘conn.php‘;  //引入数据库操作类

 

$conn=new conn();  //实例化数据库操作类

 

$total=$conn->getOne(‘select count(*) as total from goods‘);

$total=$total[‘total‘]; //goods表数据总数据条数

$num=6; //每页显示条数

$totalpage=ceil($total/$num);  //计算页数

if(isset($_GET[‘page‘]) && $_GET[‘page‘]<=$totalpage){//这里做了一个判断,若get到数据并且该数据小于总页数情况下才付给当前页参数,否则跳转到第一页

  $thispage=$_GET[‘page‘];

}else{

  $thispage=1;

}

<BR>//注意下面sql语句中红色部分,通过计算来确定从第几条数据开始取出,当前页数减去1后再乘以每页显示数据条数

$sql=‘select goods_id,goods_name,shop_price from goods order by goods_id limit ‘.<SPAN style="COLOR: #ff0000">($thispage-1)*$num</SPAN>.‘,‘.$num.‘‘;

 

$data=$conn->getAll($sql);

 

foreach($data as $k=>$v){

  echo ‘<li>‘.$v[‘goods_id‘].‘、‘.$v[‘goods_name‘].‘---¥‘.$v[‘shop_price‘].‘</li>‘;  

}

<BR>//显示分页数字列表

for($i=1;$i<=$totalpage;$i++){

  echo ‘<a href="?page=‘.$i.‘">‘.$i.‘</a> ‘

   

}

上述代码实现了一个最简单的PHP分页效果:

仅实现点击翻页数字显示不同的翻页数据,可以在此基础上进一步完善,只要基础原理理解后,后续工作就比较容易开发了。

conn.php代码:

?


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

/*

*连接数据库 进行相关查询操作

*/

 

class conn{

 

  public function __construct(){

    include_once(‘config.php‘);

    try{  

      $this->pdo = new PDO(‘mysql:host=localhost;dbname=test‘, ‘root‘, ‘123456‘);

      $this->pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

      $this->pdo->exec(‘set names utf8‘);

       

 

    }catch(PDOException $e){

      echo ‘数据库连接失败:‘.$e->getMessage();

      exit();

    }

  }

   

  //获取一行数据

  public function getOne($sql){

    $rs=$this->pdo->query($sql)->fetch(PDO::FETCH_ASSOC);

     

    return $rs;

  }

   

  //获取多行数据结果

  public function getAll($sql){

    $rs=$this->pdo->query($sql)->fetchall(PDO::FETCH_ASSOC);

     

    return $rs;

 

  }

}

conn.php功能是完成数据库连接,并实现取出数据操作方法,这里我使用的是pdo,这里可以根据大家习惯来组织代码。

config.php:

?


1

2

3

4

5

6

7

8

*

*配置数据库信息

*/

 

$cfg_dbhost=‘localhost‘;

$cfg_dbname=‘test‘;

$cfg_dbuser=‘root‘;

$cfg_dbpw=‘123456‘;

该例子仅是为了说明基础的分页原理,距真正使用还有很多修改地方。

以上就是小编为大家带来的PHP分页初探 一个最简单的PHP分页代码的简单实现的全部内容了,希望大家喜欢哦~

原文地址:https://www.cnblogs.com/angelebaby/p/8723580.html

时间: 2024-08-26 17:34:15

PHP分页初探 一个最简单的PHP分页代码的简单实现的相关文章

PHP分页初探 一个最简单的PHP分页代码实现

PHP分页代码在各种程序开发中都是必须要用到的,在网站开发中更是必选的一项. 要想写出分页代码,首先你要理解SQL查询语句:select * from goods limit 2,7.PHP分页代码核心就是围绕这条语句展开的,SQL语句说明:查询goods数据表从第2条数据开始取出7条数据.在分页代码中,7表示每页显示多少条内容,2通过公式计算表示翻页数,通过传入不同参数替换“2”的值,即可筛选出不同的数据. index.php: include 'conn.php'; //引入数据库操作类 $

Struts分页的一个实现

在Web应用程序里,分页总让我们开发人员感到很头疼,倒不是因为技术上有多么困难,只是本来和业务没有太多关系的这么一个问题,你却得花不少功夫来处理.要是稍不留神,时不时出点问题就更郁闷了.我现在做的一个项目也到了该处理分页的时候了,感觉以前处理得都不好,所以这次有所改变,基本目标是在现有(未分页)的代码基础上,尽量少做修改,并且同样的代码可以应用于不同模块的分页.以下就是我用的方法: 首先,考虑分页绝大多数发生在列表时,组合查询时也需要用到.在我的项目里,列表的Action一般名字为ListXXX

简单的beego分页功能代码

一个简单的beego分页小插件(源代码在最下面): 支持条件查询 支持参数保留 支持自定义css样式 支持表/视图 支持参数自定义 默认为pno 支持定义生成链接的个数 使用方式: 1)action中,引入包,然后如下使用: /** * 日志列表 */ func (this *LogController) List() { pno, _ := this.GetInt("pno") //获取当前请求页 var tlog []m.Tb_log var conditions string =

一个操作系统的实现(6)-初识分页机制

这节仍然是从实现的角度来讲述分页机制. 为什么要引入分页机制.我们都知道分段机制是为了提供保护机制,那么为什么还要引入分页机制呢? 为什么引入分页机制 想象一下这样一种情况:假设我们用的计算机物理内存是4GB,但是我们的程序大小是5GB.那么这个时候我们无法将程序全部放到内存中,也就无法运行程序.分页机制引入的原因之一就是为了解决这个问题.分页机制的引入实现了虚拟存储器的机制. 另外,程序执行具有局部性,也就是说一段时间内,只需要程序代码中的一小部分(相对于整个程序)就可以实现程序的执行.那么我

初学者如何做一个简单的计算器,代码分享

先新建一个类 startCalculator 声明如下 #import <Foundation/Foundation.h> @interface StartCalculator : NSObject //声明两个要计算的变量 @property float opValue1; @property float opValue2; //声明一个运算符 @property char op; //普通方法 //- (float) gzyWorkAdd; // //- (float) gzyWorkSu

这两天自己模仿写的一个Asp.Net的显示分页方法 附加实体转换和存储过程

之前自己一直用Aspnetpager控件来显示项目中的分页,但是每次都要拖一个aspnetpager的控件进去,感觉很不舒服,因为现在自己写的webform都不用服务器控件了,所以自己仿照aspnetpager写了一个精简实用的返回分页显示的html方法,其他话不说了,直接上代码. 分页显示信息的实体类:  public class Pager    {        private string _firstPageText;        /// <summary>        ///

100行代码实现简单目录浏览器制作

给大家分享使用Lae软件开发工具开发小应用程序的过程,希望大家喜欢! 界面部分我们用lae软件开发工具实现,无需写代码,业务逻辑部分使用Lae软件开发平台自带的LuaIDE编辑器,使用100行lua代码完成简单目录浏览器的制作. lae软件下载地址: https://github.com/ouloba/laetool.git lae软件下载地址(国内):https://pan.baidu.com/s/1ckMy0Q 相关视频: http://www.tudou.com/listplay/aly7

关于数字证书理解的简单整理以及12306网站证书简单分析

首先简单理解一下什么是数字证书.这里是一篇英文文档,描述的很形象.形象的描述了什么是公钥,什么是私钥,如果确保数字证书的可靠性等. 下面,我们看一个应用"数字证书"的实例:https协议.这个协议主要用于网页加密. 一般我们电脑的浏览器中都有一些受信任的证书颁发机构列表, 里边存储的都是一些机构的信息.这些机构都是权威的.当然可以通过安装软件的方式,来增加证书颁发机构,比如中国银行的根证书软件,阿里巴巴的根证书软件.默认我们认为这些软件都是从官网下载的,是绝对的没被篡改的,可靠的.简单

大话设计模式_简单工厂模式(Java代码)

简单的描述:一个父类.多个子类,实例化那个子类由一个单独的工厂类来进行 图片摘自大话设计模式: 运算类: 1 package com.longsheng.simpleFactory; 2 3 public class Calculate { 4 5 private double firstNum; 6 private double secondNum; 7 8 public double getFirstNum() { 9 return firstNum; 10 } 11 12 public v