ocinewcursor

(PHP 3>= 3.0.8, PHP 4 , PHP 5)

ocinewcursor --  Retourne un nouveau pointeur à utiliser pour lier les pointeurs de références

Description

resource ocinewcursor ( resource conn )

ocinewcursor() alloue un nouveau pointeur de commande, pour la connexion conn.

Exemple 1. Utiliser un REF CURSOR issue d'une procédure enregistrée

<?php   
// supposons que votre procédure stockée info.output retourne un curseur de référence dans :data

$conn = OCILogon("scott", "tiger");
$curs = OCINewCursor($conn);
$stmt = OCIParse($conn, "begin info.output(:data); end;");

ocibindbyname($stmt, "data", $curs, -1, OCI_B_CURSOR);
ociexecute($stmt);
ociexecute($curs);

while (
OCIFetchInto($curs, $data)) {
    
var_dump($data);
}

OCIFreeStatement($stmt);
OCIFreeCursor($curs);
OCILogoff($conn);
?>

Exemple 2. Utiliser un REF CURSOR issue d'une commande SELECT

<?php   
echo '<html><body>';
$conn = OCILogon("scott","tiger");
$count_cursor = "CURSOR(select count(empno) num_emps from emp " .
                
"where emp.deptno = dept.deptno) as EMPCNT from dept";
$stmt = OCIParse($conn,"select deptno,dname,$count_cursor");

ociexecute($stmt);
echo
'<table>';
echo
'<tr>';
echo
'<th>DEPT NAME</th>';
echo
'<th>DEPT #</th>';
echo
'<th># EMPLOYEES</th>';
echo
'</tr>';

while (
OCIFetchInto($stmt,&$data,OCI_ASSOC)) {
    echo
'<tr>';
    
$dname  = $data["DNAME"];
    
$deptno = $data["DEPTNO"];
    echo
'<td>' . $dname . '</td>';
    echo
'<td>' . $deptno . '</td>';
    
ociexecute($data["EMPCNT"]);
    while (
OCIFetchInto($data["EMPCNT"],&$subdata,OCI_ASSOC)) {
        
$num_emps = $subdata["NUM_EMPS"];
        echo
'<td>' . $num_emps . '</td>';
    }
    echo
'</tr>';
}
echo
'</table>';
echo
'</body></html>';
OCIFreeStatement($stmt);
OCILogoff($conn);
?>

Note : Cette fonction a été renommée en oci_new_cursor() pour PHP version 5.0.0 et plus récent. Pour la compatibilité ascendante, ocinewcursor() peut toujours être utilisée. Toutefois, elle est obsolète.