分享
 
 
 

分页显示Oracle数据库记录的PHP类

王朝oracle·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

<?php

/*********************************************

TOracleViewPagev 2.0

日期:2000-9-23

分页显示Oracle数据库记录的类

更新日期:2000-10-19

增加显示TopRecord的功能,允许第一页显示的记录数与其它页不同。

作者:sharetop

email:ycshowtop@21cn.com

***********************************************/

class TOracleViewPage {

var $Table; //表名

var $MaxLine; //每页显示行数

var $LinkId; //数据库连接号

var $Id; //排序参考字段

var $Offset; //记录偏移量

var $Total; //记录总数

var $Number; //本页读取的记录数

var $TopNumber;//读新记录时实际取出的记录数

var $Result; //读出的结果

var $TopResult;//读新记录时的结果

var $TheFirstPage;//特殊指定第一页的链接

var $StartRec; //指定第二页的起始记录号

var $TPages; //总页数

var $CPages; //当前页数

var $TGroup;

var $PGroup; //每页显示的页号个数

var $CGroup;

var $Condition; //显示条件 如:where id='$id' order by id desc

var $PageQuery; //分页显示要传递的参数

//-------------------------------------

// 以下构造函数、析构函数及初始化函数

//-------------------------------------

//构造函数

//参数:表名、最大行数、分页参考的字段、每页显示的页号数

function TOracleViewPage($TB,$ML,$id){

global $offset;

$this->Table=$TB;

$this->MaxLine=$ML;

$this->Id=$id;

$this->StartRec=0;

if(isset($offset)) $this->Offset=$offset;

else $this->Offset=0;

$this->Condition="";

$this->TheFirstPage=NULL;

$this->PageQury=NULL;

}

//初始化

//参数:用户名、密码、数据库

function InitDB($user,$password,$db){

if (PHP_OS == "WINNT") $dllid=dl("php3_oci80.dll");

$this->LinkId = OCILogon($user,$password,$db);

}

//断开

function Destroy(){

OCILogoff($this->LinkId);

}

//-------------------------

// Set 函数

//-------------------------

//设置显示条件

//如:where id='$id' order by id desc

//要求是字串,符合SQL语法(本字串将加在SQL语句后)

function SetCondition($s){

$this->Condition=$s;

}

//设置每组的显示个数

function SetNumGroup($pg){

$this->PGroup=$pg;

}

//设置首页,如无则为NULL

function SetFirstPage($fn){

$this->TheFirstPage=$fn;

}

//设置起始记录,如无则取默认0

function SetStartRecord($org){

$this->StartRec=$org;

}

//设置传递参数

// key参数名 value参数值

// 如:setpagequery("id",$id);如有多个参数要传递,可多次调用本函数。

function SetPageQuery($key,$value){

$tmp[key]=$key; $tmp[value]=$value;

$this->PageQuery[]=$tmp;

}

//--------------------------------

// Get 函数

//--------------------------------

//取记录总数

function GetTotalRec(){

$SQL="SELECT Count(*) AS total FROM ".$this->Table." ".$this->Condition;

$stmt = OCIParse($this->LinkId,$SQL);

$bool = OCIExecute($stmt);

if (!$bool) {

echo "连接失败!";

OCILogoff($this->LinkId);

exit;

}

else {

OCIFetch($stmt);

$this->Total=OCIResult($stmt,1);

}

OCIFreeStatement($stmt);

}

//取总页数、当前页

function GetPage(){

$this->TPages=ceil($this->Total/$this->MaxLine);

$this->CPages=ceil($this->Offset/$this->MaxLine)+1;

}

//取总组数、当前组

function GetGroup() {

$this->TGroup=ceil($this->TPages/$this->PGroup);

$this->CGroup=ceil($this->CPages/$this->PGroup);

}

//--------------------------------

// 工作函数

//--------------------------------

//读取记录

//主要工作函数,根据所给的条件从表中读取相应的记录

//返回值是一个二维数组,Result[记录号][字段名]

function ReadList() {

$SQL="SELECT * FROM ".$this->Table." ".$this->Condition." ORDER BY ".$this->Id." DESC";

$stmt = OCIParse($this->LinkId,$SQL);

$bool = OCIExecute($stmt);

if (!$bool) {

echo "连接失败!";

OCILogoff($this->LinkId);

exit;

}

else {

$ncols = OCINumCols($stmt);

for ( $i = 1; $i <= $ncols; $i++ )

$column_name[$i] = OCIColumnName($stmt,$i);

$k=0;

for($j=0;$j<$this->StartRec+$this->Offset;$j++) OCIFetch($stmt);

for($j=0;$j<$this->MaxLine;$j++){

if(OCIFetch($stmt)){

$k++;

for($i=1;$i<=$ncols;$i++)

$temp[$column_name[$i]]=OCIResult($stmt,$i);

$this->Result[]=$temp;

}

else break;

}

$this->Number=$k;

}

OCIFreeStatement($stmt);

return $this->Result;

}

//读最新的记录

//topnum指定要读出的记录数

function ReadTopList($topnum){

$SQL="SELECT * FROM ".$this->Table." ".$this->Condition." ORDER BY ".$this->Id." DESC";

$stmt = OCIParse($this->LinkId,$SQL);

$bool = OCIExecute($stmt);

if (!$bool) {

echo "连接失败!";

OCILogoff($this->LinkId);

exit;

}

else {

$ncols = OCINumCols($stmt);

for ( $i = 1; $i <= $ncols; $i++ )

$column_name[$i] = OCIColumnName($stmt,$i);

$k=0;

for($j=0;$j<$topnum;$j++){

if(OCIFetch($stmt)){

$k++;

for($i=1;$i<=$ncols;$i++)

$temp[$column_name[$i]]=OCIResult($stmt,$i);

$this->TopResult[]=$temp;

}

else break;

}

$this->TopNumber=$k;

}

OCIFreeStatement($stmt);

return $this->TopResult;

}

//---------------------------

// 分页相关

//---------------------------

//显示当前页及总页数

//本函数在GetPage()后调用。

function ThePage() {

echo "第".$this->CPages."页/共".$this->TPages."页";

}

//显示翻页按钮

//此函数要在GetPage()函数之后调用

//显示下页、上页,并加上要传递的参数

function Page() {

$k=count($this->PageQuery);

$strQuery=""; //生成一个要传递参数字串

for($i=0;$i<$k;$i++){

$strQuery.="&".$this->PageQuery[$i][key]."=".$this->PageQuery[$i][value];

}

return $strQuery;

}

function PrePage($strQuery){

$prev=$this->Offset-$this->MaxLine;

if($prev>=0)

echo "<A href=$PHP_SELF?offset=".$prev.$strQuery." class=newslink>上一页</A>";

else if($this->TheFirstPage!=NULL)

echo "<A href=".$this->TheFirstPage." class=newslink>上一页</A>";

else echo "上一页";

}

function NexPage($strQuery){

$next=$this->Offset+$this->MaxLine;

$k=$this->Total-$this->StartRec;

if($next<$k)

echo "<A href=$PHP_SELF?offset=".$next.$strQuery." class=newslink>下一页</A>";

else

echo "下一页";

}

//------------------------------------

// 记录分组

//----------------------------------

//显示分组

function NumPage() {

$first=($this->CGroup-1)*($this->PGroup)+1;

$last=($first+$this->PGroup > $this->TPages)? ($this->TPages+1):($first+$this->PGroup);

$pr=($this->CGroup-2>=0)?( ($this->CGroup-2)*($this->PGroup)+1 ):(-1);

$prev=($pr!=-1)?( ($pr-1)*$this->MaxLine):(0);

$ne=($this->CGroup*$this->PGroup+1<=$this->TPages)?($this->CGroup*$this->PGroup+1):(-1);

$next=($ne!=-1)?( ($ne-1)*$this->MaxLine):(0);

$k=count($this->PageQuery);

$strQuery=""; //生成一个要传递参数字串

for($i=0;$i<$k;$i++){

$strQuery.="&".$this->PageQuery[$i][key]."=".$this->PageQuery[$i][value];

}

if($first!=1)

echo "<A href=$PHP_SELF?offset=".$prev.$strQuery." > << </a>";

for($i=$first;$i<$last;$i++) {

if($this->CPages!=$i){

$current=($i-1)*$this->MaxLine;

echo "<A href=$PHP_SELF?offset=".$current.$strQuery." >".$i."</a> ";

}

else echo "<font color=#e00729>".$i."</font> ";

}

if($ne!=-1)

echo "<A href=$PHP_SELF?offset=".$next.$strQuery." > >> </a>";

}

//******end class

}

?>

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有