PHP+MySQL中实现分页

你只需要在需要添加页的页面加入这几行代码

<?php
include ‘form.class.php‘;

$p=new Page(100, ‘Demo01.php‘);//这里需要传递两个参数,参数一是分页中每页默认要显示的条数,参数二是本页面的链接地址

echo $p->ShowDiv();

?>

实现分类的页Page.class.php

<?php
class Page{
private $pageNum; //当前页
private $pageCount; //总页数
private $pageSize; //每页行数
private $rowCount; //总行数
private $url; //转跳的原地址

//__get()方法用来获取私有属性
public function __get($property_name)
{
if(isset($this->$property_name))
{
return($this->$property_name);
}
else
{
return(NULL);
}
}
//__set()方法用来设置私有属性
public function __set($property_name, $value)
{
$this->$property_name = $value;
}

//给以上变量赋值
function __construct($rowCount,$url){
//在地址栏取pageNum和pageSize变量的值
if(isset($_GET["page"])){
$this->pageNum=$_GET["page"];
$this->pageSize=$_GET["pageSize"];
}else{
$this->pageNum=1;
$this->pageSize=3;
}
//通过传进来的参数给rowCount和url赋值
$this->rowCount=$rowCount;
$this->url=$url;
//通过计算求得页面总数
$this->pageCount=intval($rowCount/$this->pageSize)+($rowCount%$this->pageSize?1:0);
}

/**
* 画界面
*/
function ShowDiv(){

//判断是否是第一页或最后一页,确定转跳地址
$nextPage=$this->pageNum+($this->pageNum<$this->pageCount? 1:0);
$lastPage=$this->pageNum-($this->pageNum>1? 1:0);

//首页和上一页
$div="<div style=‘text-align: center;‘>";
//设置每页显示行数,放到表单里提交时可以显示到地址栏(a标签设置不用表单)
$div.="<form action=‘{$this->url}‘ method=‘get‘>";
$div.="共【{$this->rowCount}】条数据 <a href=‘{$this->url}?page=1&pageSize={$this->pageSize}‘>首页</a> ";
$div.="<a href=‘{$this->url}?page={$lastPage}&pageSize={$this->pageSize}‘>上一页</a> ";

//12345的页数,用当前页面数判断显示哪些数字
if($this->pageCount<5){
for($i=1;$i<=$this->pageCount;$i++){
if($this->pageNum==$i){
$div.="<a>{$i}</a> ";
}else{
//a标签的数字和page相对应
$div.="<a href=‘{$this->url}?page={$i}&pageSize={$this->pageSize}‘>{$i}</a> ";
}
}
}else if($this->pageNum<=3){
for($i=1;$i<=5;$i++){
if($this->pageNum==$i){
$div.="<a>{$i}</a> ";
}else{
$div.="<a href=‘{$this->url}?page={$i}&pageSize={$this->pageSize}‘>{$i}</a> ";
}
}
}else if($this->pageNum>3&&$this->pageNum<$this->pageCount-3){
for($i=$this->pageNum-2;$i<=$this->pageNum+2;$i++){
if($this->pageNum==$i){
$div.="<a>{$i}</a> ";
}else{
$div.="<a href=‘{$this->url}?page={$i}&pageSize={$this->pageSize}‘>{$i}</a> ";
}
}
}else{
for($i=$this->pageCount-4;$i<=$this->pageCount;$i++){
if($this->pageNum==$i){
$div.="<a>{$i}</a> ";
}else{
$div.="<a href=‘{$this->url}?page={$i}&pageSize={$this->pageSize}‘>{$i}</a> ";
}
}
}

//下一页、末页和显示
$div.="<a href=‘{$this->url}?page={$nextPage}&pageSize={$this->pageSize}‘>下一页</a> ";
$div.="<a href=‘{$this->url}?page={$this->pageCount}&pageSize={$this->pageSize}‘>末页</a> ";
$div.="当前第【{$this->pageNum}】页,共【{$this->pageCount}】页 ";

$div.="<input type=‘hidden‘ value=‘1‘ name=‘page‘ /> ";//开头用page是否存在判断的
$div.="每页<input style=‘width: 30px‘ type=‘text‘ value=‘{$this->pageSize}‘ name=‘pageSize‘/>行 ";
$div.="<input type=‘submit‘ value=‘设置‘ name=‘btnSet‘ /></form>";
$div.="</div>";
return $div;
}
}

?>

时间: 2024-08-01 09:38:30

PHP+MySQL中实现分页的相关文章

MySQL中的分页操作结合python

mysql中的分页操作结合python --分页: --方式1: select * from ta12 limit 10;-- 读取十行 select * from ta12 limit 10,10 --从第十行读取 往后再读十行 --方式2: select * from ta12 limit 10 offset 20 ; --从第二十行开始读取10行 -- 结合python 分页: page = input('请输入要查看的页码') page = int(page) select * from

Mysql中的分页处理

先来说一下Mysql中limit的语法: --语法: SELECT * FROM table LIMIT [offset,] rows | rows OFFSET offset --举例: select * from table limit 5; --返回前5行 select * from table limit 0,5; --同上,返回前5行 select * from table limit 5,10; --返回6-15行 Mysql中分页主要利用limit能够根据偏移量返回结果的特性: s

[数据库]Oracle和mysql中的分页总结

物理分页 •在sql查询时,从数据库只检索分页需要的数据 •通常不同的数据库有着不同的物理分页语句 •mysql物理分页,采用limit关键字 •例如:检索11-20条 select * from user limit 10,10 ; * 每次只查询10条记录.当点击下一页的时候,查询数据库,查询后10条. * 优点:如果数据量非常大,不会导致内存溢出. * 缺点:每次都与数据库进行交互. * 分页一般采用数据库的sql语句完成分页查询. * MYSQL分页:使用limit关键字. * Orac

优化 MySQL 中的分页

英文:Robert Eisele 译者:Giraffe 链接:http://yemengying.com/2016/05/28/optimized-pagiantion-mysql/ 一道面试的问题,当MySQL表中有数据量很大的时候如何做分页....当时只知道在数据量很大的时候可以分表,但不知道不分表时可以怎么做....唉,谁让代理商就那么几条数据,一个简单的limit,offset就完全hold住了(捂脸)... 很多应用往往只展示最新或最热门的几条记录,但为了旧记录仍然可访问,所以就需要个

mybatis在mysql中的分页扩展

applicationContext.xml <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource" /> <property name="configLocation" value=&q

sql server和mysql中分别实现分页功能

MySQL 在MySQL中,可以用 Limit 来查询第 m 列到第 n 列的记录, 例如: select * from tablename limit m, n sql="select * from users order by userId limit "+(pageNow-1)*pageSize+","+pageSize ; 获取分页后每页的数据: //分页显示用户的 信息 public ArrayList getUsersByFenye(int pageSi

20.MySQL中的LIMIT(分页)

对于一次性查询出的大量记录,不仅不便于阅读查看,还会浪费系统效率.MySQL中提供了一个关键字LIMIT,可以限定记录的数量,也可以指定查询从哪一条记录开始(通常用于分页). 1.准备 1 CREATE DATABASE mahaiwuji; 2 USE mahaiwuji; 3 4 CREATE TABLE stu ( 5 id int(10), 6 name varchar(20), 7 sex int(5), 8 PRIMARY KEY (id) 9 ) ENGINE=InnoDB DEF

MongoDB和MySQL中的large skip问题、count问题

large skip 在为数据分页时,一般要skip多少记录并limit多少记录,例如在MySQL中: SELECT * FROM large_table ORDER BY `id` LIMIT 10000, 30 这个过程是很慢的,因为数据库需要从第一个记录开始扫描到第10000个记录,这个比较耗时. 在http://idning.github.io/point-large-skip.html对上面的sql代码总结了两个优化方法: 方法1: SELECT t.* FROM ( SELECT i

Oracle数据库中的分页--rownum

1. 介绍 当我们在做查询时,经常会遇到如查询限定行数或分页查询的需求,MySQL中可以使用LIMIT子句完成,在MSSQL中可以使用TOP子句完成,那么在Oracle中,我们如何实现呢? Oracle提供了一个rownum的伪列,它会根据返回记录生成一个序列化的数字. rownum和rowid都是伪列,但是两者的根本是不同的.rownum是根据SQL查询出的结果给每行分配一个逻辑编号,所以SQL不同也就会导致最终rownum不同:rowid是物理结构上的,在每条记录INSERT到数据库中时,都