亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

一個ORACLE分頁程序,挺實用的.

2019-11-18 20:17:16
字體:
來源:轉載
供稿:網友
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">
<HTML>
<HEAD>
<TITLE>Paging Test</TITLE>
<META NAME="Generator" CONTENT="TextPad 4.0">
<META NAME="Author" CONTENT="?">
<META NAME="KeyWords" CONTENT="?">
<META NAME="Description" CONTENT="?">
</HEAD>

<BODY BGCOLOR="#FFFFFF" TEXT="#000000" LINK="#FF0000" VLINK="#800000" ALINK="#FF00FF" BACKGROUND="?">
<?php

// How to split the result into pages, like 'limits' in MySQL?
// ===========================================================
// Tutorial by Neil Craig (neilc@netactive.co.za)
// Date: 2001-06-05
// With this example, I will explain paging of database queries where the
// result is more than the developer want to PRint to the page, but wish to
// split the result into seperate pages.
// The table "SAMPLE_TABLE" accessed in this tutorial has 4 fields:
// PK_ID, FIELD1, FIELD2 and FIELD3. The types don't matter but you should
// define a primary key on the PK_ID field.

$display_rows = 5;     // The rows that should be display at a time. You can
                       // modify this if you like.

// Connect to the Oracle database
putenv("ORACLE_SID=purk");
putenv("ORACLE_HOME=/export/oracle8i");
putenv("TNS_ADMIN=$ORACLE_HOME/network/admin");
$OracleDBConn = OCILogon("purk","purk","lengana.world");

// This query counts the records
$sql_count = "SELECT COUNT(*) FROM SAMPLE_TABLE";

// Parse the SQL string & execute it
$row_count=OCIParse($OracleDBConn, $sql_count);       
OCIExecute($row_count);

// From the parsed & executed query, we get the amount of records found.
// I'm not storing this result into a session variable because it allows for
// new records to be shown as it is entered by another user while the result
// is printed.
if (OCIFetch($row_count)) {
    $num_rows = OCIResult($row_count,1);
} else {
    $num_rows = 0;        // If no record was found
}

// Free the resources that were used for this query
OCIFreeStatement($row_count);

// We need to prepare the query that will print the results as a page. I will
// explain the query to you in detail.

// If no page was specified in the url (ex. http://mysite.com/result.php?page=2),
// set it to page 1.
if (empty($page) || $page == 0) {
    $page = 1;
}

// The start range from where the results should be printed
$start_range = (($page - 1) * $display_rows) + 1;

// The end range to where the results should be printed
$end_range = $page * $display_rows;

// The main query. It consists of 3 "SELECT" statements nested into each
// other. The center query is the query you would normally use to return the
// records you want. Do you ordering and "WHERE" clauses in this statement.
// We select the rows to limit our results but because the row numbers are
// assigned to the rows before any ordering is done, lets the code print the
// result unsorted.
// The second nested "SELECTED" assigns the new row numbers to the result
// for us to select from.

$sql = "SELECT PK_ID, FIELD1, FIELD2, FIELD3, ROW_NO FROM (SELECT PK_ID, ";
$sql .= "FIELD1, FIELD2, FIELD3, ROWNUM ROW_NO FROM (SELECT PK_ID, FIELD1, ";
$sql .= "FIELD2, FIELD3 FROM SAMPLE_TABLE ORDER BY FIELD3)) WHERE ROW_NO BETWEEN ";
$sql .= $start_range." AND ".$end_range;

// start results formatting
echo "<table width='95%' border='1' cellspacing='1' cellpadding='2' align='center'>";
echo "<tr bgcolor='#666666'>";
echo "<td><b><font color='#FFFFFF'>PK ID</font></b></td>";
echo "<td><b><font color='#FFFFFF'>Field 1</font></b></td>";
echo "<td><b><font color='#FFFFFF'>Field 2</font></b></td>";
echo "<td><b><font color='#FFFFFF'>Field 3</font></b></td>";
echo "<td><b><font color='#FFFFFF'>Row No</font></b></td>";
echo "</tr>";

if ($num_rows != 0) {

    // Parse the SQL string & execute it
    $rs=OCIParse($OracleDBConn, $sql);       
    OCIExecute($rs);
    
    // get number of columns for use later
    $num_columns = OCINumCols($rs);
    
    while (OCIFetch($rs)){
        echo "<tr>";
        for ($i = 1; $i < ($num_columns + 1); $i++) {
            $column_value = OCIResult($rs,$i);
            echo "<TD>$column_value</TD>";
        }
        echo "</tr>";
    }
        
} else {

    // Print a message stating that no records was found
    echo "<tr><td align=center>Sorry! No records was found</td></tr>";
}

// Close the table
echo "</TABLE>";

// free resources and close connection
OCIFreeStatement($rs);
OCILogoff($OracleDBConn);

?>
<div align=center>
<?php

// Here we will print the links to the other pages

// Calculating the amount of pages
if ($num_rows % $display_rows == 0) {
    $total_pages = $num_rows / $display_rows;
} else {
    $total_pages = ($num_rows / $display_rows) + 1;
    settype($total_pages, integer); // Rounding the variable
}

// If this is not the first page print a link to the previous page
if ($page != 1) {
    echo "<a href='".$PHP_SELF."?page=".($page - 1)."'>Previous</a>";
}

// Now we can print the links to the other pages
for ($i = 1; $i <= $total_pages;  $i++) {
    if ($page == $i){
        // Don't print the link to the current page
        echo " ".$i;
    } else {
        //Print the links to the other pages
        echo " <a href='".$PHP_SELF."?page=".$i."'>".$i."</a>";
    }
}

// If this is not the last page print a link to the next page
if ($page < $total_pages) {
    echo " <a href='".$PHP_SELF."?page=".($page + 1)."'>Next</a>";
}

?>
</div>
<?php

// I'm just adding this section to print some of the variables for extra info
// and some debugging

echo "<p><b>Total pages: </b>".$total_pages."</p>";
echo "<p><b>Number of records: </b>".$num_rows."</p>";
echo "<p><b>The SQL Query is:</b> ".$sql."</p>";

?>
</BODY>
</HTML>

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
精品爽片免费看久久| 亚洲区中文字幕| 成人福利网站在线观看| 国产成人精品免费视频| 国产欧美一区二区三区久久人妖| 美女撒尿一区二区三区| 91在线观看免费高清| www.日韩视频| 亚洲大胆美女视频| 久久艳片www.17c.com| 亚洲国产成人精品电影| 中日韩美女免费视频网站在线观看| 午夜欧美大片免费观看| 国产91精品最新在线播放| 亚洲一区www| 成人免费大片黄在线播放| 91在线观看免费观看| 欧美理论电影在线观看| 丝袜美腿精品国产二区| 国模私拍一区二区三区| 国内精品久久久久久久| 久久福利视频导航| 国产日韩欧美自拍| 中文字幕精品网| 一区二区三区视频免费在线观看| 欧美一级高清免费| 亚洲精品中文字幕女同| 欧美激情免费在线| 亚洲精品一区二三区不卡| 亚洲视频欧美视频| 欧美激情欧美狂野欧美精品| xxxxx成人.com| 久久高清视频免费| 久久精品亚洲一区| 久久97久久97精品免视看| 欧美整片在线观看| 日韩av黄色在线观看| 日韩在线视频导航| 中国china体内裑精亚洲片| 精品亚洲一区二区三区在线播放| 色综合久久久久久中文网| 亚洲色图偷窥自拍| 欧美性在线观看| 色yeye香蕉凹凸一区二区av| 性欧美xxxx视频在线观看| 国产一区二区三区在线免费观看| 亚洲欧洲在线视频| 精品久久久久久国产91| 久久人人爽人人爽人人片亚洲| 日本道色综合久久影院| 日韩在线一区二区三区免费视频| 国内精品久久久久久| 国产精品久久久久久一区二区| 亚洲人成电影在线| 一区二区三区四区视频| 国产成人精品国内自产拍免费看| 久久久亚洲精品视频| www.亚洲免费视频| 日韩精品免费一线在线观看| 亚洲女人天堂成人av在线| 久久久噜噜噜久久中文字免| 亚洲第一中文字幕| 国产精品高清免费在线观看| 成人国产精品免费视频| 九九热r在线视频精品| 国产精品自产拍在线观| 日韩欧美高清视频| 午夜精品www| 综合网日日天干夜夜久久| 日韩少妇与小伙激情| 国产精品三级在线| 日韩h在线观看| 国产亚洲精品综合一区91| 日韩精品有码在线观看| 欧美日韩在线观看视频小说| 国产一区二区三区在线| 亚洲欧美一区二区三区在线| 日韩精品极品在线观看播放免费视频| 久久精品视频99| 成人精品久久av网站| 日韩电影免费观看在线观看| 精品亚洲一区二区| 亚洲白拍色综合图区| 91精品国产91久久久久久不卡| 国产精品视频网站| 狠狠躁夜夜躁人人躁婷婷91| 国产一区二区日韩精品欧美精品| 欧美性xxxx极品hd欧美风情| 亚洲欧美综合v| 日本欧美在线视频| 国产91精品久久久| 欧美日韩成人在线观看| 亚洲精品456在线播放狼人| 91精品国产91久久久久久不卡| 国产精品91久久| 欧美高清视频在线| 奇门遁甲1982国语版免费观看高清| 国产欧美精品在线播放| 国产成人福利网站| 中文字幕日韩av电影| 欧美黑人巨大xxx极品| 国产精品高清免费在线观看| 日韩一区二区久久久| 懂色av一区二区三区| 操91在线视频| 97在线视频精品| 日韩成人网免费视频| 91在线高清免费观看| 日韩欧美亚洲成人| 精品福利在线观看| 亚洲电影在线看| 中文字幕久精品免费视频| 欧美日本亚洲视频| 亚洲精品福利在线观看| 精品视频一区在线视频| 久久久国产精品亚洲一区| www.亚洲人.com| 欧美日韩一区二区免费在线观看| 亚洲欧美国产精品专区久久| 欧美激情二区三区| 国产精品久久久av久久久| 国产极品jizzhd欧美| 久久精品欧美视频| 久久伊人免费视频| 亚洲毛片一区二区| 欧美疯狂做受xxxx高潮| 久久视频在线直播| 欧美日韩亚洲精品内裤| 色综合影院在线| 懂色aⅴ精品一区二区三区蜜月| 日韩免费在线看| 国产免费一区二区三区在线能观看| 91精品久久久久久久久不口人| 96精品久久久久中文字幕| 国产午夜精品久久久| 国产日韩中文字幕| 日韩男女性生活视频| 国产精品三级美女白浆呻吟| 日韩一区视频在线| 精品国产乱码久久久久久婷婷| 91最新在线免费观看| 日韩二区三区在线| 亚洲二区在线播放视频| 日韩精品在线观看一区| 欧美成人免费在线视频| 久久久精品国产一区二区| 欧美激情亚洲另类| 欧美一级视频在线观看| 久久99精品久久久久久噜噜| 欧美二区乱c黑人| 亚洲午夜女主播在线直播| 国产一区二区三区视频| 欧美电影免费播放| 欧美日韩综合视频| 欧美一区二区视频97| 亚洲黄色av网站| 在线观看日韩专区| 欧美亚洲第一区| 最新的欧美黄色| 亚洲国产另类 国产精品国产免费| 中文字幕日韩免费视频| 一本色道久久88精品综合| 亚洲人高潮女人毛茸茸| 国产一区二区欧美日韩|