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


Posted in PHP onOctober 09, 2006

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

PHP 相关文章推荐
php生成EXCEL的东东
Oct 09 PHP
PHP 中的面向对象编程:通向大型 PHP 工程的办法
Dec 03 PHP
缓存技术详谈―php
Dec 14 PHP
php session 预定义数组
Mar 16 PHP
php $_ENV为空的原因分析
Jun 01 PHP
提高PHP编程效率的53个要点(经验小结)
Sep 04 PHP
destoon出现验证码不显示时的紧急处理方法
Aug 22 PHP
wordpress安装过程中遇到中文乱码的处理方法
Apr 21 PHP
yii使用bootstrap分页样式的实例
Jan 17 PHP
ajax+php实现无刷新验证手机号的实例
Dec 22 PHP
PHP二维数组实现去除重复项的方法【保留各个键值】
Dec 21 PHP
PHP实现15位身份证号转18位的方法分析
Oct 16 PHP
在线竞拍系统的PHP实现框架(一)
Oct 09 #PHP
用在PHP里的JS打印函数
Oct 09 #PHP
在PHP的图形函数中显示汉字
Oct 09 #PHP
PHP中在数据库中保存Checkbox数据(2)
Oct 09 #PHP
PHP中显示格式化的用户输入
Oct 09 #PHP
提升PHP执行速度全攻略(下)
Oct 09 #PHP
PHP的面向对象编程
Oct 09 #PHP
You might like
php实现12306火车票余票查询和价格查询(12306火车票查询)
2014/01/14 PHP
Yii rules常用规则示例
2016/03/15 PHP
js实现运行代码需要刷新的解决方法
2007/08/18 Javascript
9个javascript语法高亮插件 推荐
2009/07/18 Javascript
javascript 实现简单的table排序及table操作练习
2012/12/28 Javascript
jquery 定位input元素的几种方法小结
2013/07/28 Javascript
将文本输入框内容加入表中的js代码
2013/08/18 Javascript
超棒的响应式布局jQuery插件Freetile.js
2014/11/17 Javascript
浅谈Javascript如何实现匀速运动
2014/12/19 Javascript
javascript实现信息增删改查的方法
2015/07/25 Javascript
JS实现选项卡实例详解
2015/11/17 Javascript
jquery+CSS3实现3D拖拽相册效果
2016/07/18 Javascript
Vuejs第十篇之vuejs父子组件通信
2016/09/06 Javascript
使用axios实现上传图片进度条功能
2017/12/21 Javascript
js实现上传并压缩图片效果
2018/01/10 Javascript
Mac下通过brew安装指定版本的nodejs教程
2018/05/17 NodeJs
vue项目中仿element-ui弹框效果的实例代码
2019/04/22 Javascript
Vue + Element UI图片上传控件使用详解
2019/08/20 Javascript
jquery中attr、prop、data区别与用法分析
2019/09/25 jQuery
[58:37]Serenity vs Fnatic 2018国际邀请赛淘汰赛BO1 8.21
2018/08/22 DOTA
[01:04:29]DOTA2-DPC中国联赛 正赛 Phoenix vs XG BO3 第二场 1月31日
2021/03/11 DOTA
python3.5 + PyQt5 +Eric6 实现的一个计算器代码
2017/03/11 Python
python opencv旋转图像(保持图像不被裁减)
2018/07/26 Python
计算机二级python学习教程(2) python语言基本语法元素
2019/05/16 Python
Python 中的参数传递、返回值、浅拷贝、深拷贝
2019/06/25 Python
Python 使用指定的网卡发送HTTP请求的实例
2019/08/21 Python
Java Spring项目国际化(i18n)详细方法与实例
2020/03/20 Python
Python描述符descriptor使用原理解析
2020/03/21 Python
pandas.DataFrame.drop_duplicates 用法介绍
2020/07/06 Python
HTML5 实战PHP之Web页面表单设计
2011/10/09 HTML / CSS
在对linux系统分区进行格式化时需要对磁盘簇(或i节点密度)的大小进行选择,请说明选择的原则
2012/11/24 面试题
入党申请人的自我鉴定
2013/12/01 职场文书
护士在校生自荐信
2014/02/01 职场文书
捐款倡议书范文
2014/02/02 职场文书
生产车间管理制度
2015/08/04 职场文书
放假通知怎么写
2015/08/18 职场文书