3、简单代码
请详细阅读以下代码,自己调试运行一次,最好把它修改一次,加上自己的功能,比如搜索等等 。
?php
// 建立数据库连接
$link = mysql_connect("localhost", "mysql_user", "mysql_password")
or die("Could not connect: " . mysql_error());
// 获取当前页数
if( isset($_GET['page']) ){
$page = intval( $_GET['page'] );
}
else{
$page = 1;
}
// 每页数量
$PageSize = 10;
// 获取总数据量
$sql = "select count(*) as amount from table";
$result = mysql_query($sql);
$row = mysql_fetch_row($result);
$amount = $row['amount'];
// 记算总共有多少页
if( $amount ){
if( $amount$page_size ){ $page_count = 1; }//如果总数据量小于$PageSize , 那么只有一页
if( $amount % $page_size ){//取总数据量除以每页数的余数
$page_count = (int)($amount / $page_size) + 1;//如果有余数 , 则页数等于总数据量除以每页数的结果取整再加一
}else{
$page_count = $amount / $page_size;//如果没有余数,则页数等于总数据量除以每页数的结果
}
}
else{
$page_count = 0;
}
// 翻页链接
$page_string = '';
if( $page == 1 ){
$page_string .= '第一页|上一页|';
}
else{
$page_string .= 'a href="https://www.04ip.com/?page=1";第一页/a|a href="https://www.04ip.com/?page='."($page-1).'上一页/a|';
}
if( ($page == $page_count) || ($page_count == 0) ){
$page_string .= '下一页|尾页';
}
else{
$page_string .= 'a href="https://www.04ip.com/?page='."($page+1).'下一页/a|a href="https://www.04ip.com/?page='."$page_count.'尾页/a';
}
// 获取数据,以二维数组格式返回结果
if( $amount ){
$sql = "select * from table order by id desc limit ". ($page-1)*$page_size .", $page_size";
$result = mysql_query($sql);
while ( $row = mysql_fetch_row($result) ){
$rowset[] = $row;
}
}else{
$rowset = array();
}
// 没有包含显示结果的代码,那不在讨论范围,只要用foreach就可以很简单的用得到的二维数组来显示结果
?
4、OO风格代码
以下代码中的数据库连接是使用的pear db类进行处理
?php
// FileName: Pager.class.php
// 分页类,这个类仅仅用于处理数据结构,不负责处理显示的工作
Class Pager
{
var $PageSize;//每页的数量
var $CurrentPageID;//当前的页数
var $NextPageID;//下一页
var $PreviousPageID;//上一页
var $numPages;//总页数
var $numItems;//总记录数
var $isFirstPage;//是否第一页
var $isLastPage;//是否最后一页
var $sql;//sql查询语句
function Pager($option)
{
global $db;
$this-_setOptions($option);
// 总条数
if ( !isset($this-numItems) )
{
$res = $db-query($this-sql);
$this-numItems = $res-numRows();
}
// 总页数
if ( $this-numItems0 )
{
if ( $this-numItems$this-PageSize ){ $this-numPages = 1; }
if ( $this-numItems % $this-PageSize )
{
$this-numPages= (int)($this-numItems / $this-PageSize) + 1;
}
else
{
$this-numPages = $this-numItems / $this-PageSize;
}
}
else
{
$this-numPages = 0;
}
switch ( $this-CurrentPageID )
{
case $this-numPages == 1:
$this-isFirstPage = true;
$this-isLastPage = true;
break;
case 1:
$this-isFirstPage = true;
$this-isLastPage = false;
break;
case $this-numPages:
$this-isFirstPage = false;
$this-isLastPage = true;
break;
default:
$this-isFirstPage = false;
$this-isLastPage = false;
推荐阅读
- 启动系统自带虚拟机好吗,启动系统自带虚拟机好吗安全吗
- 苹果号能不能转移安卓手机,苹果手机能不能电话转移
- 在线观看html5,在线观看斗罗大陆免费全集高清
- 线下棋牌室游戏有哪些项目,线上线下棋牌类牌照
- mysql路径怎么查看 查看mysql数据文件路径
- C语言教学系统设计开题报告,c语言课题设计总结
- 苹果入门机和安卓旗舰机,苹果机子好还是安卓机子好
- 分布式爬虫ip,分布式爬虫技术
- go语言队列 golang消息队列