重庆分公司,新征程启航

为企业提供网站建设、域名注册、服务器等服务

php数据添加分页 php数据库分页是怎么实现的

php怎么做分页

php分页是很经典的问题,百度一搜一大把的案例代码!首先确认总数,然后确认每页多少条数据,然后分了多少页,最后形成分页!加油

创新互联公司"三网合一"的企业建站思路。企业可建设拥有电脑版、微信版、手机版的企业网站。实现跨屏营销,产品发布一步更新,电脑网络+移动网络一网打尽,满足企业的营销需求!创新互联公司具备承接各种类型的成都做网站、网站设计、外贸营销网站建设项目的能力。经过10多年的努力的开拓,为不同行业的企事业单位提供了优质的服务,并获得了客户的一致好评。

PHP怎么制作分页

方法/步骤

首先要了解下分页的原理即

SELECT * FROM table …… limit 开始位置 , 操作条数

开始位置从0开始

SELECT * FROM table …… limit 0 , 20

取最前面20条

SELECT * FROM table …… limit 10 , 20

11条到20条

其次分页要用的公式

得到公式

(当前页数 - 1 )X 每页条数 , 每页条数

Select * from table limit ($Page- 1) * $PageSize, $PageSize

还要了解parse_url()解析URL函数

parse_url() 是讲URL解析成有固定键值的数组的函数

$ua=parse_url("");

print_r($ua);

结果:

Array

(

[scheme] = http

[host] = hostname

[user] = username

[pass] = password

[path] = /path

[query] = arg=value

[fragment] = anchor

)

创建数据库bbs和表test有

CREATE TABLE `test` (

`id` int(11) NOT NULL auto_increment,

`name` varchar(50) character set gb2312 NOT NULL,

`sex` varchar(2) character set gb2312 NOT NULL,

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=11 ;

然后插入十几条测试数据即可

写mysql数据库连接代码保存conn.php文件里

代码如下

?php

$conn = @ mysql_connect("localhost", "root", "") or die("数据库链接错误");

mysql_select_db("bbs", $conn);

mysql_query("set names 'GBK'"); //使用GBK中文编码;

function htmtocode($content) {

$content = str_replace("\n", "br", str_replace(" ", " ", $content));

return $content;

}

//$content=str_replace("'","'",$content);

//htmlspecialchars();

?

写分页函数page.php

代码如下

?php

function _PAGEFT($totle, $displaypg = 20, $url = '') {

global $page, $firstcount, $pagenav, $_SERVER;

$GLOBALS["displaypg"] = $displaypg;

if (!$page)

$page = 1;

if (!$url) {

$url = $_SERVER["REQUEST_URI"];

}

//URL分析:

$parse_url = parse_url($url);

$url_query = $parse_url["query"]; //单独取出URL的查询字串

if ($url_query) {

$url_query = ereg_replace("(^|)page=$page", "", $url_query);

$url = str_replace($parse_url["query"], $url_query, $url);

if ($url_query)

$url .= "page";

else

$url .= "page";

} else {

$url .= "?page";

}

$lastpg = ceil($totle / $displaypg); //最后页,也是总页数

$page = min($lastpg, $page);

$prepg = $page -1; //上一页

$nextpg = ($page == $lastpg ? 0 : $page +1); //下一页

$firstcount = ($page -1) * $displaypg;

//开始分页导航条代码:

$pagenav = "显示第 B" . ($totle ? ($firstcount +1) : 0) . "/B-B" . min($firstcount + $displaypg, $totle) . "/B 条记录,共 $totle 条记录";

//如果只有一页则跳出函数:

if ($lastpg = 1)

return false;

$pagenav .= " a href='$url=1'首页/a ";

if ($prepg)

$pagenav .= " a href='$url=$prepg'前页/a ";

else

$pagenav .= " 前页 ";

if ($nextpg)

$pagenav .= " a href='$url=$nextpg'后页/a ";

else

$pagenav .= " 后页 ";

$pagenav .= " a href='$url=$lastpg'尾页/a ";

//下拉跳转列表,循环列出所有页码:

$pagenav .= " 到第 select name='topage' size='1' onchange='window.location=\"$url=\"+this.value'\n";

for ($i = 1; $i = $lastpg; $i++) {

if ($i == $page)

$pagenav .= "option value='$i' selected$i/option\n";

else

$pagenav .= "option value='$i'$i/option\n";

}

$pagenav .= "/select 页,共 $lastpg 页";

}

include("conn.php");

$result=mysql_query("SELECT * FROM `test`");

$total=mysql_num_rows($result);

//调用pageft(),每页显示10条信息(使用默认的20时,可以省略此参数),使用本页URL(默认,所以省略掉).

_PAGEFT($total,5);

echo $pagenav;

$result=mysql_query("SELECT * FROM `test` limit $firstcount,$displaypg ");

while($row=mysql_fetch_array($result)){

echo "hrb".$row[name]." | ".$row[sex];

}

?

调用数据和分页list.php

?php

/**

* 爱微网

*/

include("conn.php");

$pagesize=5;

$url=$_SERVER["REQUEST_URI"];

$url=parse_url($url);

$url=$url[path];

$numq=mysql_query("SELECT * FROM `test`");

$num = mysql_num_rows($numq);

if($_GET[page]){

$pageval=$_GET[page];

$page=($pageval-1)*$pagesize;

$page.=',';

}

if($num $pagesize){

if($pageval=1)$pageval=1;

echo "共 $num 条".

" a href=$url?page=".($pageval-1)."上一页/a a href=$url?page=".($pageval+1)."下一页/a";

}

echo $SQL="SELECT * FROM `test` limit $page $pagesize ";

$query=mysql_query($SQL);

while($row=mysql_fetch_array($query)){

echo "hrb".$row[name]." | ".$row[sex];

}

?

注意事项

注意分页公式写法你只要记住即可;

(当前页数 - 1 )X 每页条数 , 每页条数;

Select * from table limit ($Page- 1) * $PageSize, $PageSize;

注意三个代码文件在同一个目录下;

主要是最后的list.php调用代码要细看很有用。

thinkphp数据分页怎么使用

第一种:利用Page类和limit方法

$User = M('User'); // 实例化User对象

import('ORG.Util.Page');// 导入分页类

$count = $User-where('status=1')-count();// 查询满足要求的总记录数

$Page = new Page($count,25);// 实例化分页类 传入总记录数和每页显示的记录数

$show = $Page-show();// 分页显示输出

// 进行分页数据查询 注意limit方法的参数要使用Page类的属性

$list = $User-where('status=1')-order('create_time')-limit($Page-firstRow.','.$Page-listRows)-select();

$this-assign('list',$list);// 赋值数据集

$this-assign('page',$show);// 赋值分页输出

$this-display(); // 输出模板

第二种:分页类和page方法的实现

$User = M('User'); // 实例化User对象

// 进行分页数据查询 注意page方法的参数的前面部分是当前的页数使用 $_GET[p]获取

$list = $User-where('status=1')-order('create_time')-page($_GET['p'].',25')-select();

$this-assign('list',$list);// 赋值数据集

import(“ORG.Util.Page”);// 导入分页类

$count = $User-where('status=1')-count();// 查询满足要求的总记录数

$Page = new Page($count,25);// 实例化分页类 传入总记录数和每页显示的记录数

$show = $Page-show();// 分页显示输出

$this-assign('page',$show);// 赋值分页输出

$this-display(); // 输出模板

带入查询条件

如果是POST方式查询,如何确保分页之后能够保持原先的查询条件呢,我们可以给分页类传入参数,方法是给分页类的parameter属性赋值:

import('ORG.Util.Page');// 导入分页类

$mapcount = $User-where($map)-count();// 查询满足要求的总记录数

$Page = new Page($count,25);// 实例化分页类 传入总记录数和每页显示的记录数

//分页跳转的时候保证查询条件

foreach($map as $key=$val) {

$Page-parameter .= "$key=".urlencode($val).'';

}

$show = $Page-show();// 分页显示输出

thinkphp怎么对已提取的数据分页

我们已经了解了如何进行数据查询,今天我们来学习下如何对数据进行分页以及显示。

获取分页类

ThinkPHP提供了数据分页的扩展类库Page,可以在下载,或者下载官方的完整扩展包()里面也已经包含分页扩展类了。把解压后的Page.class.php放入ThinkPHP/Extend/Library/ORG/Util/(如果没有请手动创建)目录下面。

当然,扩展类库的位置其实比较随意,你也可以放入项目的类库目录下面,区别只是在于你导入路径的不同而已。

分页查询

分页类需要和查询相结合,我们可以使用ThinkPHP自带的limit方法或者page方法,目的就是为了获取当前分页的数据(也有先获取完整数据然后前端分页显示的方法,不在本文描述内容中,也不建议)。使用limit方法或者page方法是和数据库类型无关的。

我们首先在数据库里面创建一个think_data数据表用于测试:

CREATE TABLE IF NOT EXISTS `think_data` (

`id` smallint(4) unsigned NOT NULL AUTO_INCREMENT,

`title` varchar(255) NOT NULL,

`content` varchar(255) NOT NULL,

`create_time` int(11) unsigned NOT NULL,

PRIMARY KEY (`id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8 ;

复制代码

要使用分页查询,一般来说需要进行两次查询,即第一次查询得到满足条件的总数据量,然后第二次查询当前分页的数据,这样做的作用是告诉分页类当前的数据总数,以便计算生成的总页数(如果你的显示只是需要上下翻页的话,其实总数查询可以省略或者进行缓存)。

一个标准的分页使用示例如下:

$Data = M('Data'); // 实例化Data数据对象

import('ORG.Util.Page');// 导入分页类

$count = $Data-where($map)-count();// 查询满足要求的总记录数 $map表示查询条件

$Page = new Page($count);// 实例化分页类 传入总记录数

$show = $Page-show();// 分页显示输出

// 进行分页数据查询

$list = $Data-where($map)-order('create_time')-limit($Page-firstRow.','.$Page-listRows)-select();

$this-assign('list',$list);// 赋值数据集

$this-assign('page',$show);// 赋值分页输出

$this-display(); // 输出模板

复制代码

如果没有任何数据的话,分页显示为空白。所以在进行测试之前,请确保你的数据表里面有一定的数据,否则可能看不到分页的效果。如果使用page方法查询的话,则可以改成:

$Data = M('Data'); // 实例化Data数据对象

import('ORG.Util.Page');// 导入分页类

$count = $Data-where($map)-count();// 查询满足要求的总记录数

$Page = new Page($count);// 实例化分页类 传入总记录数

// 进行分页数据查询 注意page方法的参数的前面部分是当前的页数使用 $_GET[p]获取

$nowPage = isset($_GET['p'])?$_GET['p']:1;

$list = $Data-where($map)-order('create_time')-page($nowPage.','.$Page-listRows)-select();

$show = $Page-show();// 分页显示输出

$this-assign('page',$show);// 赋值分页输出

$this-assign('list',$list);// 赋值数据集

$this-display(); // 输出模板

复制代码

然后,我们在模板中添加分页输出变量即可:

table cellpadding=3 cellspacing=5

volist name="list" id="vo"

tr

td [ {$vo.create_time|date='Y-m-d H:i:s',###} ] {$vo.title} /td

/tr

/volist

tr

/tr

/table

div class="result page"{$page}/div

复制代码

可以看到分页输出只需要采用{$page}变量在模板中输出即可。

分页设置

设置分页变量

默认情况下,分页传值的变量是p,生成的分页跳转地址可能类似于:

复制代码

我们可以配置VAR_PAGE配置参数来改变:

'VAR_PAGE'='page'

复制代码

则分页地址变成:

复制代码

设置每页记录数

默认的情况下,分页显示每页会显示20条数据,如果你希望改变每页显示的数据量的话,实例化分页类的时候可以传人第二个参数即可:

$Page = new Page($count,5);// 实例化分页类 传入总记录数并且每页显示5条记录

复制代码

由于查询方法中我们使用了$Page-listRows属性,所以无需更改,但如果你是直接在查询方法中使用数字请记得一起更改。

下面是官方的分页示例的显示效果:

传入分页条件

默认情况下,分页类会自动获取当前页面的POST(优先)或者GET变量作为分页跳转的传值,如果需要指定传入当前分页跳转的参数,就可以通过设置parameter属性,parameter属性支持2种方式传值:字符串和数组。字符串采用var1=val1var2=val2...的格式,例如:

foreach($map as $key=$val) {

$Page-parameter .= "$key=".urlencode($val).'';

}

复制代码

或者直接传入数组:

$Page-parameter = array_map('urlencode',$map);

复制代码

由于内部调用了U函数,分页类最终生成的分页跳转链接会根据当前的URL设置自动生成和当前URL模式一致的地址,所以无需担心分页链接的参数影响URL地址。

分页路由支持

如果你的分页跳转链接地址采用了路由,那么可以通过设置url参数,例如,假设我们的分页URL地址格式是:

复制代码

这样的URL路由地址,那么我们就可以设置

$Page-url = 'data/index';

复制代码

设置后,分页类的链接地址会自动生成上面的URL格式地址。

注意,url参数和parameter 同时使用的话,后者无效。

设置显示的页数

可以在实例化分页类之后,进行相关属性的设置。默认情况下,页面显示的页数是5,我们可以修改:

$Page-rollPage = 3;

复制代码

这样,页面上只能同时看到3个分页

分页显示定制

上面讲的是分页的参数设置,下面讲下如何对分页显示效果(包括样式)进行设置。默认的分页效果可能不能满足所有的要求,分页类提供了一个setConfig方法来修改默认的一些设置。例如:

$page-setConfig('header','个会员');

复制代码

setConfig方法支持的属性包括:

header 头部描述信息,默认值 “条记录”

prev 上一页描述信息,默认值是“上一页”

next 下一页描述信息,默认值是“下一页”

first 第一页描述信息,默认值是“第一页”

last 最后一页描述信息,默认值是“最后一页”

theme 分页主题描述信息,包括了上面所有元素的组合 ,设置该属性可以改变分页的各个单元的显示位置,默认值是

"%totalRow% %header% %nowPage%/%totalPage% 页 %upPage% %downPage% %first% %prePage% %linkPage% %nextPage% %end%"

通过setConfig设置以上属性可以完美的定制出你的分页显示风格。

php分页怎么弄?

原理:

1.设定每页显示数

$num = 15;

2.获取数据总数计算总页数

3.通过get方法获取页码,无获取值页码为1,超过最大页数为最大页面数

$page = $_GET['page'] ? $_GET['page'] : 1;

4.通过页码来计算当前显示起始记录

$start = $page*$num-1;

5.通过sql语句查询

query("select * from tablename limit $start,$num");

然后输出就行了

页面上可以循环输出1~总页数 这些数字来实现翻页,也可以用其他方法

比较方便的方法是,可以去找一个分页类

我的php页面代码如下,效果如下,请问如何添加分页效果?代码怎么写啊?

$perNumber=10; //每页显示的记录数

$page=$_GET['page']; //获得当前的页面值

$count=mysql_query("select count(*) from td_oa"); //获得记录总数

$rs=mysql_fetch_array($count);

$totalNumber=$rs[0];

$totalPage=ceil($totalNumber/$perNumber); //计算出总页数

if (!isset($page)) {

$page=1;

} //如果没有值,则赋值1

$startCount=($page-1)*$perNumber; //分页开始,根据此方法计算出开始的记录

$result=mysql_query("select * from user limit $startCount,$perNumber"); //根据前面的计算出开始的记录和记录数

while ($row=mysql_fetch_array($result)) {

echo "user_id:".$row[0]."br";

echo "username:".$row[1]."br"; //显示数据库的内容

}

if ($page != 1) { //页数不等于1

?

a href="fenye.php?page=?php echo $page - 1;?"上一页/a !--显示上一页--

?php

}

for ($i=1;$i=$totalPage;$i++) { //循环显示出页面

?

a href="fenye.php?page=?php echo $i;?"?php echo $i ;?/a

?php

}

if ($page$totalPage) { //如果page小于总页数,显示下一页链接

?

a href="fenye.php?page=?php echo $page + 1;?"下一页/a

?php

}

?


网站栏目:php数据添加分页 php数据库分页是怎么实现的
地址分享:http://cqcxhl.com/article/hjdhcj.html

其他资讯

在线咨询
服务热线
服务热线:028-86922220
TOP