oci_new_cursor

新規カーソル (ステートメントハンドル) を割り当て、それを返す

説明

resourcefalse oci_new_cursor(resource $connection)

指定された接続に新規カーソルを割り当てます。

パラメータ

connection

oci_connect あるいは oci_pconnect が返す Oracle 接続 ID。

戻り値

新しいステートメントハンドル、あるいはエラー時に false を返します。

例1 Oracle ストアドプロシージャにおける REF CURSOR のバインド

<?php

// 以下のプロシージャを用意します
//   create or replace procedure myproc(myrc out sys_refcursor) as
//   begin
//     open myrc for select first_name from employees;
//   end;

$conn oci_connect("hr""hrpwd""localhost/XE");
if (!
$conn) {
    
$m oci_error();
    
trigger_error(htmlentities($m['message']), E_USER_ERROR);
}

$curs oci_new_cursor($conn);
$stid oci_parse($conn"begin myproc(:cursbv); end;");
oci_bind_by_name($stid":cursbv"$curs, -1OCI_B_CURSOR);
oci_execute($stid);

oci_execute($curs);  // REF CURSOR を、ステートメント ID のように利用します
while (($row oci_fetch_array($cursOCI_ASSOC+OCI_RETURN_NULLS)) != false) {
    echo 
$row['FIRST_NAME'] . "<br />\n";
}

oci_free_statement($stid);
oci_free_statement($curs);
oci_close($conn);

?>