首頁 > 後端開發 > php教程 > 分頁顯示Oracle資料庫記錄的類別之一_PHP教學課程

分頁顯示Oracle資料庫記錄的類別之一_PHP教學課程

WBOY
發布: 2016-07-21 16:10:31
原創
824 人瀏覽過


<?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[]=$tmpery[]=$tmpery ;
}
//--------------------------------
// 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);
}

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/314257.htmlTechArticle<?php /******************** ************************* TOracleViewPagev 2.0 日期:2000-9-23 分頁顯示Oracle資料庫記錄的類別更新日期:2000-10-19 增加顯示TopReco...
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板