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.