OCILogon

OCILogon -- Oracle への接続を確立する

説明

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

  1 
  2 <?php
  3 print "<HTML><PRE>";
  4 $db = "";
  5 
  6 $c1 = ocilogon("scott","tiger",$db);
  7 $c2 = ocilogon("scott","tiger",$db);
  8 
  9 function create_table($conn)
 10 { $stmt = ociparse($conn,"create table scott.hallo (test
 11 varchar2(64))");
 12   ociexecute($stmt);
 13   echo $conn." created table\n\n";
 14 }
 15 
 16 function drop_table($conn)
 17 { $stmt = ociparse($conn,"drop table scott.hallo");
 18   ociexecute($stmt);
 19   echo $conn." dropped table\n\n";
 20 }
 21 
 22 function insert_data($conn)
 23 { $stmt = ociparse($conn,"insert into scott.hallo values('$conn' || ' ' || to_char(sysdate,'DD-MON-YY HH24:MI:SS'))");
 24   ociexecute($stmt,OCI_DEFAULT);
 25   echo $conn." inserted hallo\n\n";
 26 }
 27 
 28 function delete_data($conn)
 29 { $stmt = ociparse($conn,"delete from scott.hallo");
 30   ociexecute($stmt,OCI_DEFAULT);
 31   echo $conn." deleted hallo\n\n";
 32 }
 33 
 34 function commit($conn)
 35 { ocicommit($conn);
 36   echo $conn." commited\n\n";
 37 }
 38 
 39 function rollback($conn)
 40 { ocirollback($conn);
 41   echo $conn." rollback\n\n";
 42 }
 43 
 44 function select_data($conn)
 45 { $stmt = ociparse($conn,"select * from scott.hallo");
 46   ociexecute($stmt,OCI_DEFAULT);
 47   echo $conn."----selecting\n\n";
 48   while (ocifetch($stmt))
 49     echo $conn." <".ociresult($stmt,"TEST").">\n\n";
 50   echo $conn."----done\n\n";
 51 }
 52 
 53 create_table($c1);
 54 insert_data($c1);   // c1 を用いて行を挿入
 55 insert_data($c2);   // c2 を用いて行を挿入
 56 
 57 select_data($c1);   // 両方の挿入の結果を返す
 58 select_data($c2);   
 59 
 60 rollback($c1);      // c1 を用いてロールバック
 61 
 62 select_data($c1);   // 両方の挿入がロールバックされた
 63 select_data($c2);   
 64 
 65 insert_data($c2);   // c2 を用いて行を挿入
 66 commit($c2);        // c2 を用いてコミット
 67 
 68 select_data($c1);   // 挿入 c2 の結果が返される
 69 
 70 delete_data($c1);   // c1 を用いてテーブルの全ての行を削除
 71 select_data($c1);   // 行を返さない
 72 select_data($c2);   // 行を返さない
 73 commit($c1);        // c1 を用いてコミット
 74 
 75 select_data($c1);   // 行を返さない
 76 select_data($c2);   // 行を返さない
 77 
 78 
 79 drop_table($c1);
 80 print "</PRE></HTML>";
 81 ?>

OCIPLogon() および OCINLogon() も参照下さい。