'PageSize',
'CurrentPageID',
'sql',
'numItems'
);
foreach ( $option as $key = $value )
{
if ( in_array($key, $allow_options)($value != null) )
{
$this-$key = $value;
}
}
return true;
}
}
?
?php
// FileName: test_pager.php
// 这是一段简单的示例代码,前边省略了使用pear db类建立数据库连接的代码
require "Pager.class.php";
if ( isset($_GET['page']) )
{
$page = (int)$_GET['page'];
}
else
{
$page = 1;
}
$sql = "select * from table order by id";
$pager_option = array(
"sql" = $sql,
"PageSize" = 10,
"CurrentPageID" = $page
);
if ( isset($_GET['numItems']) )
{
$pager_option['numItems'] = (int)$_GET['numItems'];
}
$pager = @new Pager($pager_option);
$data = https://www.04ip.com/post/$pager-getPageData();
if ( $pager-isFirstPage )
{
$turnover = "首页|上一页|";
}
else
{
$turnover = "a href='https://www.04ip.com/post/?page=1numItems=".$pager-numItems."'首页/a|a href="https://www.04ip.com/?page=".$pager-PreviousPageID."numItems=".$pager-numItems."'上一页/a|";
}
if ( $pager-isLastPage )
{
$turnover .= "下一页|尾页";
}
else
{
$turnover .= "a href="https://www.04ip.com/?page=".$pager-NextPageID."numItems=".$pager-numItems."'下一页/a|a href="https://www.04ip.com/?page=".$pager-numPages."numItems=".$pager-numItems."'尾页/a";
}
?
需要说明的地方有两个:
这个类仅仅处理数据 , 并不负责处理显示,因为我觉得将数据的处理和结果的显示都放到一个类里边实在是有些勉强 。显示的时候情况和要求多变 , 不如自己根据类给出的结果处理 , 更好的方法是根据这个Pager类继承一个自己的子类来显示不同的分页 , 比如显示用户分页列表可以:
?php
Class MemberPager extends Pager
{
function showMemberList()
{
global $db;
$data = https://www.04ip.com/post/$this-getPageData();
// 显示结果的代码
// ......
}
}
/// 调用
if ( isset($_GET['page']) )
{
$page = (int)$_GET['page'];
}
else
{
$page = 1;
}
$sql = "select * from members order by id";
$pager_option = array(
"sql" = $sql,
"PageSize" = 10,
"CurrentPageID" = $page
);
if ( isset($_GET['numItems']) )
{
$pager_option['numItems'] = (int)$_GET['numItems'];
}
$pager = @new MemberPager($pager_option);
$pager-showMemberList();
?
第二个需要说明的地方就是不同数据库的兼容性,在不同的数据库里截获一段结果的写法是不一样的 。
mysql: select * from table limit offset, rows
pgsql: select * from table limit m offset n
......
所以要在类里边获取结果的时候需要使用pear db类的limitQuery方法 。
ok,写完收功,希望花时间看完这些文字的php分页获取不同数据库你不觉得是浪费了时间 。
php 查询数据库 分页说明你点下一页的时候,查询条件没有获取到,下一页的是连接,所以接受数据参数的时候需要用$_GET 来接收,提交的时候也需要用get方法提交,这样才能保证参数不会丢失,点击下一页的时候限制条件保持一致
PHP显示很多数据库信息,如何自动分页呢?代码PHP代码如下:
/*
Author:默默
Date :2006-12-03
*/
$page=isset($_GET['page'])?intval($_GET['page']):1; //这句就是获取page=18中php分页获取不同数据库的page的值php分页获取不同数据库,假如不存在page,那么页数就是1 。
$num=10; //每页显示10条数据
- 纯phpmysql
- 查找php.ini phpredis查找
- redis怎么获取list的值 redis中存取list
- 如何获取云服务器的源代码? 云服务器源代码怎么弄
- mysqli获取所有数据 mysql的提取函数
- php7连接mysql php连接mysql源码
- mongodb添加节点 mongodb获取主节点ip
- mongodbtemplate分页 mongodb如何分页
- mysql分页性能优化 mysql分页执行很慢
- mysql分页有什么优化 mysql分页功能
