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

2016-02-19 12:11 2 1 收藏

下面,图老师小编带您去了解一下分页显示Oracle数据库记录的类之二,生活就是不断的发现新事物,get新技能~

【 tulaoshi.com - Web开发 】


//--------------------------------
// 工作函数
//--------------------------------

//读取记录
//主要工作函数,根据所给的条件从表中读取相应的记录
//返回值是一个二维数组,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
}
?

来源:https://www.tulaoshi.com/n/20160219/1600155.html

延伸阅读
SQL*DBA命令的安全性: 如果您没有SQL*PLUS应用程序,您也可以使用SQL*DBA作SQL查权限相关的命令只能分配给Oracle软件拥有者和DBA组的用户,因为这些命令被授予了特殊的系统权限。 (1) startup (2) shutdown (3) connect internal 数据库文件的安全性: Oracle软件的拥有者应该这些数据库文件($ORA...
DBA日常管理 目的:这篇文档有很详细的资料记录着对一个甚至更多的ORACLE数据库每天的,每月的,每年的运行的状态的结果及检查的结果,在文档的附录中你将会看到所有检查,修改的SQL和PL/SQL代码。 目录 1.日常维护程序 A.检查已起的所有实例 B.查找一些新的警告日志 C.检查DBSNMP是否在运行 D.检查数...
1、SQL Server、Access数据库 这都微软的数据库,都是一家人,基本的操作都是差不多,常采用如下分页语句: PAGESIZE:每页显示的记录数 CURRENTPAGE:当前页号 数据表的名字是:components 索引主键字是:id 以下是引用片段: selecttopPAGESIZE*fromcomponentswhereidnotin (selecttop(PAGESIZE*(CURRENTPAGE...
作为一个Oracle数据库开发者或者DBA,在实际工作中经常会遇到这样的问题:试图对库表中的某一列或几列创建唯一索引时,系统提示ORA-01452:不能创建唯一索引,发现重复记录。 下面我们以表code_ref为例来讨论这个问题及其解决办法。 ERROR位于第1行: ORA-01452: 无法 CREATE UNIQUE INDEX;找到重复的关键字 Oracle系...
      每个数据库管理员都会面临数据导入的问题,这有可能发生在数据库的新老移植过程中,或者是在数据库崩溃后的恢复重建过程中,还有可能是在创建测试数据库的模拟环境过程中,总之作为一名合格的数据库管理员,你应该做好接受各种数据导入请求的技术储备,同时还要尽量满足人本能的对导入速度的苛求。本文仅针对 O...

经验教程

369

收藏

58
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部