OCINLogon
(PHP 3>= 3.0.8, PHP 4 )
OCINLogon -- Új Oracle adatbázis kapcsolat létrehozása
Leírás
int
OCINLogon ( string username, string password [, string db])
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.
Példa 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().