oci_new_cursor

(PHP 5)

oci_new_cursor -- Alloue un nouveau curseur Oracle

Description

resource oci_new_cursor ( resource connection )

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

Exemple 1. Utiliser un REF CURSOR issu 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 = oci_connect("scott", "tiger");
$curs = oci_new_cursor($conn);
$stmt = oci_parse($conn, "begin info.output(:data); end;");

oci_bind_by_name($stmt, "data", $curs, -1, OCI_B_CURSOR);
oci_execute($stmt);
oci_execute($curs);

while (
$data = oci_fetch_row($curs)) {
    
var_dump($data);
}

oci_free_statement($stmt);
oci_free_statement($curs);
oci_close($conn);
?>

Exemple 2. Utiliser un REF CURSOR issu 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 border="1">';
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);
?>

oci_new_cursor() retourne FALSE en cas d'erreur.

Note : Dans les versions de PHP antérieures à la version 5.0.0, vous devez utiliser la fonction ocinewcursor(). Cet ancien nom est toujours utilisable : un alias a été fait vers la fonction oci_new_collection(), pour assurer la compatibilité ascendante. Toutefois, il est recommandé de ne plus l'utiliser.

Hosting by: Hurra Communications GmbH
Generated: 2007-01-26 18:02:12