int OCILogon
(string username, string password, string [db]);OCILogon は他のほとんどの OCI コールで必要な 接続 ID を返します。 オプションの3番目のパラメータには、ローカルOracleインスタンスの名前か tnsnames.ora における接続先のエントリ名を指定することができます。 オプションの3番目のパラメータが指定されない場合、 PHP は接続先のデータベースを定義するために環境変数 ORACLE_SID (Oracle インスタンス)または TWO_TASK (tnsnames.ora) を使用します。
OCILogon を使用した場合、接続はページレベルで共有 されます。 このことは、多重接続を行った場合でも、コミット及びロールバックは そのページの全てのオープンされたトランザクションに適用されることを 意味します。
この例は、接続がどのように共有されるかをデモします。
例 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." 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." commited\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); // c1 を用いて行を挿入 insert_data($c2); // c2 を用いて行を挿入 select_data($c1); // 両方の挿入の結果を返す select_data($c2); rollback($c1); // c1 を用いてロールバック select_data($c1); // 両方の挿入がロールバックされた select_data($c2); insert_data($c2); // c2 を用いて行を挿入 commit($c2); // c2 を用いてコミット select_data($c1); // 挿入 c2 の結果が返される delete_data($c1); // c1 を用いてテーブルの全ての行を削除 select_data($c1); // 行を返さない select_data($c2); // 行を返さない commit($c1); // c1 を用いてコミット select_data($c1); // 行を返さない select_data($c2); // 行を返さない drop_table($c1); print "</PRE></HTML>"; ?>
OCIPLogon および OCINLogon も参照下さい。