国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > Oracle > 正文

分頁顯示Oracle數據庫記錄的PHP類

2024-08-29 13:32:42
字體:
來源:轉載
供稿:網友

  <?php

/*********************************************
toracleviewpage v 2.0
日期:2000-9-23

分頁顯示oracle數據庫記錄的類


更新日期:2000-10-19
增加顯示toprecord的功能,允許第一頁顯示的記錄數與其它頁不同。

作者:sharetop
email:[email protected]

***********************************************/
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
}
?>

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 威宁| 天长市| 新宾| 海阳市| 洛阳市| 汤阴县| 景洪市| 沙田区| 龙海市| 上饶县| 鄯善县| 和龙市| 大厂| 汉源县| 香港 | 泰和县| 龙里县| 邓州市| 凌源市| 文成县| 邵武市| 抚远县| 清丰县| 合川市| 桂东县| 大同县| 嫩江县| 丹棱县| 隆化县| 岳阳市| 苏尼特左旗| 瑞丽市| 阜阳市| 新昌县| 龙州县| 龙口市| 安塞县| 大悟县| 银川市| 北川| 岳西县|