PHP kézikönyv
Előző
Következő
Az OCILogon() egy kapcsolat azonosítóval tér vissza, amire a legtöbb OCI hívásban szükséged lesz.
Az opcionális harmadik paraméter vagy a helyi Oracle példány nevét adja meg, vagy egy tnsnames.ora bejegyzést, amihez csatlakozni szeretnél.
Ha nem adod meg ezt a paramétert, a PHP az ORACLE_SID (Oracle példány) vagy a TWO_TASK (tnsnames.ora) környezeti változókat használja, hogy eldöntse melyik adatbázishoz kell csatlakozni.
Az OCILogon() által visszaadott kapcsolatot az aktuális oldalon megosztva használja a PHP.
Ez azt jelenti, hogy a tranzakciók végrehjatása vagy visszavonása minden nyitott tranzakcióra vonatkozik az adott oldalon, még akkor is, ha több adatbázis kapcsolattal is rendelkezel.
Ez a példa bemutatja a kapcsolatok megosztását.
Példa 1.
?php print "HTML PRE"; $db = ""; $c1 = ocilogon("scott" ,"tiger",$db); $c2 = ocilogon("scott" ,"tiger",$db); function create_table($conn) {$stmt = ociparse($conn ,"create table scott.hello (proba varchar2(64))"); ociexecute($stmt); echo $conn. "tábla létrehozva\n\n";} function drop_table($conn) {$stmt = ociparse($conn ,"drop table scott.hello"); ociexecute($stmt); echo $conn." tábla törölve\n\n";} function insert_data($conn) {$stmt = ociparse($conn ,"insert into scott.hello values('$conn '| |' '| | to_char(sysdate ,'DD-MON-YY HH24:MI:SS'))"); ociexecute($stmt,OCI_DEFAULT); echo $conn. "beillesztés végrehajtva\n\n";} function delete_data($conn) {$stmt = ociparse($conn ,"delete from scott.hello"); ociexecute($stmt,OCI_DEFAULT); echo $conn." törlés végrehajtva\n\n";} function commit($conn) {ocicommit($conn); echo $conn. "tranzakció végrehajtva\n\n";} function rollback($conn) {ocirollback($conn); echo $conn." tranzakció visszavonva\n\n";} function select_data($conn) {$stmt = ociparse($conn ,"select * from scott.hello"); ociexecute($stmt,OCI_DEFAULT); echo $conn ."----select végrehajtása\n\n"; while (ocifetch($stmt)) echo $conn. "".ociresult($stmt ,"PROBA")." \n\n"; echo $conn ."----kész\n\n";} create_table($c1); insert_data($c1); / / Új sor beillesztése c1 felhasználásával insert_data($c2); / / Új sor beillesztése c2 felhasználásával select_data($c1); / / Mindkét insert eredményét megkapjuk select_data($c2); rollback($c1); / / Visszavonjuk a c1-en végzett műveletet select_data($c1); / / Mindkét műveletet visszavontuk select_data($c2); insert_data($c2); / / Sor beillesztése c2-vel commit($c2); / / Tranzakció végrehajtása c2-vel select_data($c1); / / A c2 beillesztés eredményét visszakapjuk delete_data($c1); / / A c1-el töröljük a sorokat select_data($c1); / / Egy sor sincs select_data($c2); / / Egy sor sincs commit($c1); / / A c1-el végrehajtjuk a tranzakciót select_data($c1); / / Egy sor sincs select_data($c2); / / Egy sor sincs drop_table($c1); print "/ PRE / HTML";?
Lásd még OCIPLogon() és OCINLogon().
Előző
Tartalom
Következő
Fel