频道直达 - 专题 - 新闻 - 基础 - 高级 - 安装 - 技巧 - 数据库 - 手册 - PHP - Linux - Java - MySQL - Apache - 麻辣堂 - 狼盟 - Rails社群 - 搜索 - 下载 - 开源 - 论坛
PHP开发资源网 主页>>高级应用>> 收藏此文 | 收藏本站 | 设为首页

一个odbc连mssql分页的类

来源:www.phpres.com 作者:Angelover 出处:www.phpres.com 2007-8-5 09:17:05 进入讨论组
关 键 词: 一个 // var function if this-page return page str.

<!--二泉.net -->
<?
class Pages{
var $cn;        //连接数据库游标
var $d;            //连接数据表的游标
var $result;    //结果
var $dsn;        //dsn源
var $user;        //用户名    
var $pass;        //密码

var $total;        //记录总数
var $pages;        //总页数
var $onepage;    //每页条数
var $page;        //当前页
var $fre;        //上一页
var $net;        //下一页
var $i;            //控制每页显示

function getConnect($dsn,$user,$pass){
$this->cn=@odbc_connect($dsn,$user,$pass);
if(!$this->cn){
$error="连接数据库出错";
$this->getMess($error);
}
}

function getDo($sql){//从表中查询数据
$this->d=@odbc_do($this->cn,$sql);
if(!$this->d){
$error="查询时发生了小错误......";
$this->getMess($error);
}
return $this->d;
}

function getTotal($sql){
$this->sql=$sql;
$dT=$this->getDo($this->sql);        //求总数的游标
$this->total=odbc_result($dT,'total');//这里为何不能$this->d呢?
return $this->total;
}

function getList($sql,$onepage,$page){
$this->s=$sql;
$this->onepage=$onepage;
$this->page=$page;
$this->dList=$this->getDo($this->s);    //连接表的游标
$this->pages=ceil($this->total/$this->onepage);
if($this->pages==0)
$this->pages++; //不能取到第0页
if(!isset($this->page))
$this->page=1;
$this->fre = $this->page-1;                    //将显示的页数
$this->nxt = $this->page+1;
$this->nums=($this->page-1)*$this->onepage;
//if($this->nums!=0){
//    for($this->i=0;$this->i<$pg->getNums();odbc_fetch_row($this->dd),$this->i++);//同上
//}
//$this->i=0;//为何这部分不能封装?
return $this->dList;
}

function getFanye(){
$str="";
if($this->page!=1)
$str.="<a href=".$PHP_SELF."?page=1> 首页 </a><a href=".$PHP_SELF."?page=".$this->fre."> 前页 </a>";
else
$str.="<font color=999999>首页 前页</font>";
if($this->page<$this->pages)
$str.="<a href=".$PHP_SELF."?page=".$this->nxt."> 后页 </a>";
else
$str.="<font color=999999> 后页 </font>";
if($this->page!=$this->pages)
$str.="<a href=".$PHP_SELF."?page=".$this->pages."> 尾页 </a>";
else
$str.="<font color=999999> 尾页 </font>";

$str.="共".$this->pages."页";
$str.="您正浏览第<font color=red>".$this->page."</font>页";
return $str;
}

function getNums(){
return $this->nums;
}

function getOnepage(){//每页实际条数
return $this->onepage;
}

function getI(){
return $this->i;
}

function getPage(){
return $this->page;
}

function getMess($error){//定制消息
echo"<center>$error</center>";
exit;
}
}

$pg=new Pages();
$pg->getConnect("lei","sa","star");
$pg->getTotal("select count(*) as total from xs");            //连学生表求总数
$pg->getList("select xs_name from xs order by xs_id",8,$page);
if($pg->getNums()!=0){
for($i=0;$i<$pg->getNums();odbc_fetch_row($pg->dList),$i++);//同上
}
$i=0;
while(odbc_fetch_row($pg->dList)){
$name=odbc_result($pg->dList,"xs_name");
echo $name."<br>";
if($i==$pg->getOnepage()){//跳出循环
break;
}
$i++;
}
echo$pg->getFanye();
?>欢迎进入PHP开发资源论坛讨论。
收藏此文】【 】【打印】【关闭
相关文章
图文推荐
论 坛 资 源
PHP开发资源网奋斗目标
阅读排行:
热门技术文档
最新图文档
本站编辑推荐:(本站开通Delphi4PHP专区,欢迎进入论坛交流!)
编缉最近更新文章
网站赞助商
搜索您感兴趣的内容
 
   网站首页 -  网站地图 -  网站合作 -  手册中心 -  通用网址 -  网站论坛 -  网站投稿 -  友情链接 -  帮助中心
版权所有:PHP开发资源网 © 2003-2008 通用网址:PHP资源网 合作媒体: 赛迪网IT技术
互联网违法和不良信息举报中心 | 不良信息举报信箱