中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

php數(shù)據(jù)庫(kù)連接

通過(guò)php你可以輕松的連接到數(shù)據(jù)庫(kù),請(qǐng)求數(shù)據(jù)并將其顯示在你的web站點(diǎn)中,甚至修改數(shù)據(jù)庫(kù)中的數(shù)據(jù)。MySQL是一種很流行的數(shù)據(jù)庫(kù),并且在互聯(lián)網(wǎng)中有許多有關(guān)php與MySQL的教程。MySQL是免費(fèi)的,這一點(diǎn)也許就吸引了不少人。由于其廣泛應(yīng)用,我就不想在這里贅述MySQL的使用方法了。Oracle被大量在企業(yè)應(yīng)用中采用,因此我們就利用Oracle來(lái)介紹php與數(shù)據(jù)庫(kù)的連接。我們當(dāng)然不會(huì)提及Oracle數(shù)據(jù)庫(kù)的設(shè)計(jì)原理,原因是這已經(jīng)超出了我們的討論范圍。   
php提供了兩套函數(shù)與Oracle連接,分別是ORA_和OCI函數(shù)。其中ORA_函數(shù)略顯陳舊。OCI函數(shù)更新?lián)f(shuō)更好一些。兩者的使用語(yǔ)法幾乎相差無(wú)幾。如前所述,你的php安裝選項(xiàng)應(yīng)該可以支持兩者的使用。   
想獲得更多有關(guān)在Microsoft  Windows平臺(tái)上安裝支持php3的Apache服務(wù)器的知識(shí)以及更多有關(guān)Oracle數(shù)據(jù)庫(kù)的知識(shí),請(qǐng)查閱以下URL:www.csoft.NET/~vsbabu/articles/oraphp.html。   
4.1  連接   

if  ($conn=Ora_Logon("user@TNSNAME","password"))     
{   
echo  "SUCCESS  !  Connected  to  database/n";   
}     
else     
{   
echo  "Failed  :-(  Could  not  connect  to  database/n";   
}   
Ora_Logoff($conn);   
phpinfo();   
?>   
以上代碼使用TNSNAME(在你的tnsnames.ora文件中指明)定義的Oracle數(shù)據(jù)庫(kù)名稱(chēng)、用戶名稱(chēng)和密碼連接數(shù)據(jù)庫(kù)。在成功連接的基礎(chǔ)上,ora_logon函數(shù)返回一個(gè)非零的連接ID并儲(chǔ)存在變量$conn中。   

4.2  查詢(xún)   

假設(shè)與數(shù)據(jù)庫(kù)已經(jīng)連接就緒,下面我們就來(lái)實(shí)際的應(yīng)用對(duì)數(shù)據(jù)庫(kù)的查詢(xún)。下面的代碼演示了一個(gè)連接并查詢(xún)的典型例子:   
/*   
*  連接數(shù)據(jù)庫(kù)并執(zhí)行查詢(xún)   
*/   
function  printoraerr($in_cur)   
{   
//  檢查Oracle是否出錯(cuò)   
//  如果存在錯(cuò)誤則顯示   
//  當(dāng)指針被激活時(shí)每次請(qǐng)求Oracle后調(diào)用該函數(shù)   
if(ora_errorcode($in_cur))   
echo  "Oracle  code  -  ".ora_error($in_cur)."/n";   
return;   
}   
/**  主程序  */   
if  (!($conn=ora_logon("user@TNSNAME","password")))     
{   
echo  "Connection  to  database  failed/n";   
exit;   
}   
echo  "Connected  as  connection  -  $conn
/n";   
echo  "Opening  cursor  ...
/n";   
$cursor=ora_open($conn);  printoraerr($cursor);   
echo  "Opened  cursor  -  $cursor
/n";   
$qry="select  user,sysdate  from  dual";   
echo  "Parsing  the  query  $qry  ...
/n";   
ora_parse($cursor,$qry,0);  printoraerr($cursor);   
echo  "Query  parsed   
/n";   
echo  "Executing  cursor  ...
/n";   
ora_exec($cursor);  printoraerr($cursor);   
echo  "Executed  cursor
/n";   
echo  "Fetching  cursor  ...
/n";   
while(ora_fetch($cursor))   
{   
$user=ora_getcolumn($cursor,0);  printoraerr($cursor);   
$sysdate=ora_getcolumn($cursor,1);  printoraerr($cursor);   
echo  "  row  =  $user,  $sysdate   
/n";   
}   
echo  "Fetched  all  records
/n";   
echo  "Closing  cursor  ...
/n";   
ora_close($cursor);   
echo  "Closed  cursor
/n";   
echo  "Logging  off  from  oracle...   
/n";   
ora_logoff($conn);   
echo  "Logged  off  from  oracle   
/n";   
?>   
(譯者注:以上代碼段缺少注釋?zhuān)?qǐng)讀者參考php  Manual的Oracle數(shù)據(jù)庫(kù)函數(shù)部分)   

4.3  顯示結(jié)果   

以下代碼演示了怎樣查詢(xún)數(shù)據(jù)庫(kù)并將結(jié)果輸出:   
function  printoraerr($in_cur,  $conn)   
{   
//  檢查Oracle是否出錯(cuò)   
//  如果存在錯(cuò)誤則顯示   
//  當(dāng)指針被激活時(shí)每次請(qǐng)求Oracle后調(diào)用該函數(shù)   
//  If  it  encountered  an  error,  we  exit  immediately   
if(ora_errorcode($in_cur))     
{   
echo  "Oracle  code  -  ".ora_error($in_cur)."
n";   
ora_logoff($conn);   
exit;   
}   
return;   
}   

function  exequery($w_qry,$conn)     
{   
$cursor=ora_open($conn);  printoraerr($cursor,$conn);   
ora_parse($cursor,$w_qry,0);  printoraerr($cursor,$conn);   
ora_exec($cursor);  printoraerr($cursor,$conn);   
$numrows=0;   
$w_numcols=ora_numcols($cursor);   
//  顯示頭部   
echo  "   

  /n";   
for  ($i=0;$i<$w_numcols;$i++)   
{   
$align=(ora_columntype($cursor,$i)=="NUMBER")?"RIGHT":"LEFT";   
echo  "/t  ".ora_columnname($cursor,$i)."  /n";   
}   
echo  "   
/n";   
while(ora_fetch($cursor))   
{   
echo  "  /n";   
for  ($i=0;$i<$w_numcols;$i++)     
{   
$align=(ora_columntype($cursor,$i)=="NUMBER")?"RIGHT":"LEFT";   
if(ora_columntype($cursor,$i)=="LONG")   
echo  "  ".
ora_getcolumn($cursor,$i)."
  /n";   
else   
echo  "  ".ora_getcolumn($cursor,$i)."  /n";   
printoraerr($cursor,$conn);   
}   
$numrows++;   
echo  "   
/n";   
}   
if  ($numrows==0)   
echo  "  Query  returned  no  records   

/n";   
else     
{   
echo  "  /n";   
echo  "  Count  /n";   
echo  "  $numrows  /n";   
echo  "   
/n";   
}   
echo  "  /n";   
ora_close($cursor);   
return;   
}   

//  主程序   
if(!($conn=ora_logon("user@SID","password")))     
{   
echo  "Error:  Cannot  connect  to  database/n";   
exit;   
}   
$qry="SELECT   
deptno  /"Dept/"   
,empno  /"Emp/"   
,empnm  /"Name/"   
,salary  /"Salary/"   
FROM   
employee   
ORDER  BY  1,2";   
exequery($qry);   
ora_logoff($conn);   
?>   
(譯者注:以上代碼段缺少注釋?zhuān)?qǐng)讀者參考php  Manual的Oracle數(shù)據(jù)庫(kù)函數(shù)部分)   

4.4  基于HTTP的Oracle登錄   

將以下代碼加在php頁(yè)面代碼之前以確認(rèn)Oracle登錄。注意你必須正確設(shè)定$  SID。   
if(!isset($php_AUTH_USER))     
{   
Header("WWW-authenticate:  basic  realm=/"$SID/"");   
Header("HTTP/1.0  401  Unauthorized");   
$title="Login  Instructions";   
echo  "


You  are  not  authorized  to  enter  the  site   

/n";   
exit;   
}     
else     
{   
if  (!($conn=ora_logon("$php_AUTH_USER@$SID",$php_AUTH_PW)))     
{   
Header("WWW-authenticate:  basic  realm=/"$SID/"");   
Header("HTTP/1.0  401  Unauthorized");   
$title="Login  Instructions";   
echo  "

You  are  not  authorised  to  enter  the  site   

/n";   
exit;   
}   
}   
?>   

php技術(shù)php數(shù)據(jù)庫(kù)連接,轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲影视在线 | 久久久久国产一区二区三区四区 | 欧美日韩国产精品一区二区 | 亚洲热在线视频 | 国产精品一区在线 | 青青草亚洲 | 一级毛片观看 | 亚洲久久久 | 亚洲精品欧美 | 丁香久久| 国产区精品 | 三级黄色片在线播放 | 国产精品a免费一区久久电影 | 新疆少妇videos高潮 | 呦呦在线视频 | 成人在线小视频 | 人人干97| 一级全黄少妇性色生活免费看 | 日韩视频精品 | 91亚洲精华国产 | 在线视频亚洲 | 久久69精品久久久久久久电影好 | 国产精品视频一二三区 | 日韩三区在线观看 | 毛片一级网站 | 一区二区国产精品 | 亚洲精品区 | 久久久久黄 | 成人精品视频在线观看 | 亚洲精品自在在线观看 | 91资源在线 | 久产久精国产品 | 欧美成人第一页 | 久久精品| 精品久久久久久 | 国产精品不卡一区 | 国产免费一区二区三区最新6 | 欧美精品网站 | 午夜伊人| 精品亚洲一区二区 | 亚洲日韩中文字幕一区 |