oracle
隨著網站規模的擴大,MySql顯然不能滿足需求,在許多網站都
採用大型資料庫Oracle的情況下,如何使用PHP來訪問Oracle變的越發重要了。
我從我編寫的一個簡單iERP系統談我自己是如何做的,在PHP官方手冊裡也有說明。
一般情況下或者說大多數人都是用Oracle8 Call-Interface(OCI8)來串連資料庫,
我這裡介紹不使用OCI8介面而直接使用PHP的Oracle函數來串連資料庫並處理資料。
注意:
php.ini配置中要去掉 ;extension=php_oracle.dll 前的分號即
extension=php_oracle.dll
1,串連資料庫
使用ora_logon()或者ora_plogon()來串連上資料庫
ora_plogon功能與ora_logon類似,只不過ora_plogon開啟與 Oracle 的長期連結
直至web服務停止
$handle = ora_plogon("system@localhost", "manager") or die;
"system@localhost" 其中localhost是oracle SID 名稱,system是使用者名稱稱,manager是使用者密碼
2,開啟遊標
$cursor = ora_open($handle);
3,分析文法並執行指令
$query = "select count(*) from area where areacode = '$addcode'";
ora_parse($cursor, $query) or die;
ora_exec($cursor);
4,擷取資料
if(ora_fetch($cursor))
$datacount = ora_getcolumn($cursor, 0);
5,關閉遊標
ora_close($cursor);
當然了你有可能執行的是delete或者insert語句不存在擷取資料的步驟如:
INSERT:(插入)
$handle = ora_plogon("system@localhost", "manager") or die;
ora_commiton($handle);
$cursor = ora_open($handle);
$query = "insert into area(areacode,areaname) values('$addcode','$addname')";
ora_parse($cursor, $query) or die;
ora_exec($cursor);
ora_close($cursor);
DELETE:(刪除)
$handle = ora_plogon("system@localhost", "manager") or die;
$cursor = ora_open($handle);
ora_commiton($handle);
$query = "delete from area where areacode in ('222','444')" ;
ora_parse($cursor, $query) or die;
ora_exec($cursor);
ora_close($cursor);