oracle数据库分页字段,分页显示Oracle数据库记录的类之一

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

更新时间:2006年10月09日 00:00:00   作者:

<?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);

}

相关文章

1a1b05c64693fbf380aa1344a7812747.png

[FAQ]PHP中的一些常识:类篇...2006-10-10

4f55910a645b073bc4fc65dc10dc14bd.png

PHP中对数据库操作的封装...2006-10-10

0ea3c7666119d5615e582f823fb3fad6.png

Oracle 常见问题解答...2006-10-10

4f96a78db829b1556ff16de21e013c7a.png

用PHP生成PDF文件 with FPDF...2006-10-10

8cc1031babc6aff2319f1c6af8544aa0.png

如何在PHP中进行身份认证...2006-10-10

0c932a99bb7b6f23c937db507070cc7b.png

一个很方便的 XML 类!!原创的噢...2006-10-10

cca732bf65a93ed2ec0ac80c638460fe.png

PHP最大的优点之一显然在于它的快速度,然而,当你不得不面对庞大的访问量、高负荷的应用、有限的带宽以及 其他各种带来性能瓶颈的因素时,或许只要加上一个 很不起眼的免费模块,你的PHP应用性能以及Web服务器响应速度就会有显著的改善2006-10-10

2d9f31f2af7b675a3d153d2b7f1035a7.png

随着PHP 7.0对速度进行大幅度提高之后,PHP7版本也让更多的人开始使用。所以下面这篇文章主要给大家介绍了在Centos 6.5系统下编译安装PHP 7.0.13的方法,文中通过安装的步骤一步步介绍的非常详细,有需要的朋友们可以参考借鉴,下面来一起看看吧。2016-12-12

b452cee8ec5cd9e58ab98eba17281e59.png

PHP实现的功能是显示8条基色色带...2006-10-10

f4838ec7e2d4da28e0b57d4e852dadd4.png

今天小编就为大家分享一篇关于PHP PDOStatement::execute讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧2019-01-01

最新评论

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值