ocinlogon
(PHP 3>= 3.0.8, PHP 4 )
ocinlogon -- Stabilisce, una nuova connessione a Oracle.
Descrizione
int
ocinlogon ( string username, string password [, string db])
ocinlogon() crea una nuova connessione
a un database Oracle 8 e si autentica. Il terzo parametro opzionale
può contenere il nome della istanza Oracle locale o il nome
della voce in tnsnames.ora a cui ci si vuole connettere.
Se il terzo parametro opzionale non è specificato, PHP usa la
variabile d'ambiente ORACLE_SID (istanza di Oracle) o TWO_TASK
(in tnsnames.ora) per determinare a quale database collegarsi.
ocinlogon() forza una nuova connessione.
Si deve usare quando si ha necessità di isolare un insieme di transazioni. Di
default, le connessioni sono condivise a livello di pagina se si usa
ocilogon() o a livello di processo del web server
se si usa ociplogon(). Se ci sono connessioni
multiple aperte con ocinlogon(), tutti i
commit e rollback avverranno solo sulla connessione specificata.
Questo esempio dimostra come le connessioni sono isolate.
Esempio 1. esempio di 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.hallo (test
varchar2(64))");
ociexecute($stmt);
echo $conn." created table\n\n";
}
function drop_table($conn)
{ $stmt = ociparse($conn,"drop table scott.hallo");
ociexecute($stmt);
echo $conn." dropped table\n\n";
}
function insert_data($conn)
{ $stmt = ociparse($conn,"insert into scott.hallo
values('$conn' || ' ' || to_char(sysdate,'DD-MON-YY HH24:MI:SS'))");
ociexecute($stmt,OCI_DEFAULT);
echo $conn." inserted hallo\n\n";
}
function delete_data($conn)
{ $stmt = ociparse($conn,"delete from scott.hallo");
ociexecute($stmt,OCI_DEFAULT);
echo $conn." deleted hallo\n\n";
}
function commit($conn)
{ ocicommit($conn);
echo $conn." committed\n\n";
}
function rollback($conn)
{ ocirollback($conn);
echo $conn." rollback\n\n";
}
function select_data($conn)
{ $stmt = ociparse($conn,"select * from scott.hallo");
ociexecute($stmt,OCI_DEFAULT);
echo $conn."----selecting\n\n";
while (ocifetch($stmt))
echo $conn." <".ociresult($stmt,"TEST").">\n\n";
echo $conn."----done\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>";
?> |
|
Vedere anche ocilogon() e
ociplogon().