首頁  >  文章  >  後端開發  >  php連接oracle資料庫及查詢資料實作分頁的方法

php連接oracle資料庫及查詢資料實作分頁的方法

怪我咯
怪我咯原創
2017-07-10 12:03:542547瀏覽

這篇文章主要介紹了php連接oracle資料庫及查詢資料的方法,以實例形式較為詳細的分析了php操作oracle資料庫的使用技巧,具有一定的參考借鑒價值,需要的朋友可以參考下

本文實例講述了php連接oracle資料庫及查詢資料的方法。分享給大家供大家參考。具體分析如下:

php有強大的功能不但可以支援mysql,mssql,mysqli之個我們還可以與oracle資料連接,要讓php支援oracle非常的簡單我們只要把php.ini中的; extention = php_oci8.dll分號去掉即可.

php支援oracle連線函數

php.ini檔案中的設定,去掉;extention = php_oci8.dll,去掉前面的分號,重啟apache就可以了,如果不行,我們再把php目錄中的php_oci8.dll拷到windows系統的system32下面去吧.

oracle資料庫建立連結,程式碼如下:

1.

 程式碼如下:

$conn = oci_connect('username','password',"(DEscriptION=(ADDRESS=(PROTOCOL =TCP)(HOST=192.168.1.100)(PORT = 1521))(CONNECT_DATA =(SID=test)))");

2.

程式碼如下:

$conn = oci_connect('username','password','192.168.1.100/test');

3.Oracle 連線方法:

程式碼如下:

set adocon=Server.Createobject("adodb.connection") 
adocon.open"Driver={microsoft odbc for oracle};server=oraclesever.world;uid=admin;pwd=pass;"

4.Oracle OLE DB 連線方法:

 程式碼如下:

set adocon=Server.Createobject("adodb.connection") 
adocon.open"Provider=OraOLEDB.Oracle;data source=dbname;user id=admin;password=pass;"

有的時候第一種方式不行,使用第二種,裡面的幾個參數分別是使用者名稱、密碼、oracle服務位址,其中test是服務名稱,程式碼如下:

 程式碼如下:

$sql = "select * from table_exmaple" 
$ora_test = oci_parse($conn,$sql);  //编译sql语句 
oci_execute($ora_test,OCI_DEFAULT);  //执行 
while($r=oci_fetch_row($ora_test))  //取回结果 
{ 
echo $ora_test[0]; 
echo "<BR>";   
}

看個完整的例子,如果PHP版本>5.0,那麼使用下面的函數:

程式碼如下:

oci_connect ( username, password , dbname )

範例,程式碼如下:

 程式碼如下:

<?php 
$conn = oci_connect(&#39;hr&#39;, &#39;hr&#39;, &#39;orcl&#39;); // 建立连接 
if (!$conn) { 
$e = oci_error(); 
print htmlentities($e[&#39;message&#39;]); 
exit; 
} 
$query = &#39;SELECT * FROM DEPARTMENTS&#39;; // 查询语句 
$stid = oci_parse($conn, $query); // 配置SQL语句,准备执行 
if (!$stid) { 
$e = oci_error($conn); 
print htmlentities($e[&#39;message&#39;]); 
exit; 
} 
$r = oci_execute($stid, OCI_DEFAULT); // 执行SQL。OCI_DEFAULT表示不要自动commit 
if(!$r) { 
$e = oci_error($stid); 
echo htmlentities($e[&#39;message&#39;]); 
exit; 
} 
// 打印执行结果 
print &#39;<table border="1">&#39;; 
while($row = oci_fetch_array($stid, OCI_RETURN_NULLS)) { 
print &#39;<tr>&#39;; 
foreach($row as $item) { 
print &#39;<td>&#39;.($item?htmlentities($item):&#39; &#39;).&#39;</td>&#39;; 
} 
print &#39;</tr>&#39;; 
} 
print &#39;</table>&#39;; 
oci_close($conn); 
?>

下面是分頁範例程序,看起來可能比較繁瑣,但其實你只要用一下就會發現,一切原來如此簡單

example. php

<?php 
$conn = ociplogon("test","123456","test123"); 
include_once "pager.inc.php"; 
?>
<?php 
/** 分页测试开始 */ 

// {{{ 初始分页对象 
$pager = new pager(); 
/** 将 select id,name,age from test where age>20 order by id desc 拆分 */ 
$sqlArr = array(&#39;conn&#39; => $conn, // 数据库连结 
&#39;fields&#39; => " id,name,age ", // 查询主语句 
&#39;table&#39; => "test", // 表名 
&#39;condition&#39; => " age>20 ", // 查询条件 
&#39;order&#39; => " order by id desc " // 排序方式 
); 
if (!$pager->listn($sqlArr,10,$page)) // 每页显示10条 
{ 
$pager->errno = 10; 
die($pager->errmsg()); 
} 
//}}} 

// {{{ 数据显示 
for( $i = 0; $i < count($pager->result); $i++) 
{ 
$tmp = $pager->result[$i]; 
echo " id:".$tmp[&#39;ID&#39;]."<br>"; 
echo " name:".$tmp[&#39;NAME&#39;]."<br>"; 
echo " age:".$tmp[&#39;AGE&#39;]."<hr>" 
} 
// }}} 

// {{{ 显示翻页链结 
echo $pager->page. " / ".$pager->totalpage." 共 ".$pager->total. "条记录 "; 
if ($pager->prev != 0) 
echo " <a href=$PHP_SELF?page=".$pager->prev.">上一页</a> "; 
else 
echo " 上一页 "; 

if ($pager->next != 0) 
echo " <a href=$PHP_SELF?page=".$pager->next.">下一页</a> "; 
else 
echo " 下一页 "; 
// }}} 
?> 

<?@OCILogoff($conn)?>

以上是php連接oracle資料庫及查詢資料實作分頁的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn