OCINLogon
(PHP 4, PHP 5, PECL oci8:1.0-1.2.4)
OCINLogon — Új Oracle adatbázis kapcsolat létrehozása
LeÃrás
Az OCINLogon() egy új Oracle 8 adatbázis kapcsolatot hoz létre, és bejelentkezik. 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 OCINLogon() mindenképpen egy új kapcsolatot hoz létre. Erre akkor van szükséged, ha el kell különÃtened a tranzakcióidat egymástól. Alapértelmezésben a kapcsolatokat a PHP megosztja egy oldalon belül, ha az OCILogon() függvényt használod. Az OCIPLogon() használata esetén pedig már a web szerver process szintjén érvényesül a megosztás. Ha több kapcsolatod van az OCINLogon() függvénnyel megnyitva, minden tranzakció végrehajtás és visszavonás cska az adott kapcsolatra vonatkozik.
A következő példa bemutatja a kapcsolatok elkülönülését.
Example#1 OCINLogon
<?php print "<HTML><PRE>"; $db = ""; $c1 = ocilogon("scott","tiger",$db); $c2 = ocinlogon("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); select_data($c1); select_data($c2); rollback($c1); select_data($c1); select_data($c2); insert_data($c2); commit($c2); select_data($c1); delete_data($c1); select_data($c1); select_data($c2); commit($c1); select_data($c1); select_data($c2); drop_table($c1); print "</PRE></HTML>"; ?>
Lásd még OCILogon() és OCIPLogon().