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


<?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 も参照下さい。