OCILogon
(PHP 4, PHP 5, PECL oci8:1.0-1.2.4)
OCILogon — Vytvorà spojenie s Oracle serverom
Popis
OCILogon() vráti identifikátor spojenia potrebný pre ostatné OCI volania. Nepovinný tretà parameter može obsahovať názov lokálnej inštancie Oraclu alebo názov záznamu v tnsnames.ora ku ktorému sa chcete pripojiť. Ak nepovinný parameter nie je špecifikovaný, PHP použije premennu prostredia ORACLE_SID (Oracle instance) alebo TWO_TASK (tnsnames.ora) na pripojenie k databáze.
Spojenia su zdieľané na úrovni stránky, ak sa použije OCILogon(). To znamená, že commit a rollback sú aplikované na všetky otvorené transakcie na stránke, pokiaľ nemate vytvorené viacere spojenia.
Nasledujúci prÃklad ukazuje, ako sú spojenia zdieľané.
Example#1 OCILogon
<?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.hallo (test varchar2(64))"); ociexecute($stmt); echo $conn." tabuľka vytvorená\n\n"; } function drop_table($conn) { $stmt = ociparse($conn,"drop table scott.hallo"); ociexecute($stmt); echo $conn." tabuľka zmazaná\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." vložené do tabuľky hallo\n\n"; } function delete_data($conn) { $stmt = ociparse($conn,"delete from scott.hallo"); ociexecute($stmt,OCI_DEFAULT); echo $conn." zmazané s tabuľky hallo\n\n"; } function commit($conn) { ocicommit($conn); echo $conn." spravený commit\n\n"; } function rollback($conn) { ocirollback($conn); echo $conn." spravený rollback\n\n"; } function select_data($conn) { $stmt = ociparse($conn,"select * from scott.hallo"); ociexecute($stmt,OCI_DEFAULT); echo $conn."----selektovanie\n\n"; while (ocifetch($stmt)) echo $conn." <".ociresult($stmt,"TEST").">\n\n"; echo $conn."----OK\n\n"; } create_table($c1); insert_data($c1); // vložený riadok pomocou c1 insert_data($c2); // vložený riadok pomocou c2 select_data($c1); // Vrátené sú oba vložené riadky select_data($c2); rollback($c1); // Spravený rollback pomocou c1 select_data($c1); // Oba vložené riadky boli rollback-nuté select_data($c2); insert_data($c2); // vložený riadok pomocou c2 commit($c2); // spravený commit pomocou c2 select_data($c1); // výsledok je vložený riadok pomocou c2 delete_data($c1); // zmazané všetky záznamy pomocou c1 select_data($c1); // vrátené nie sú žiadne riadky select_data($c2); // vrátené nie sú žiadne riadky commit($c1); // spravený commit pomocou c1 select_data($c1); // vrátené nie sú žiadne riadky select_data($c2); // vrátené nie sú žiadne riadky drop_table($c1); print "</PRE></HTML>"; ?>
Vid tiež OCIPLogon() a OCINLogon().