(PHP 5, PHP 7, PECL OCI8 >= 1.1.0)
oci_new_cursor — Asigna y devuelve un nuevo cursor (gestor de sentencia)
$connection
) : resourceAsigna un nuevo gestor de sentencia para la conexión especificada.
connection
Un identificador de conexión de Oracle devuelto por oci_connect() o oci_pconnect().
Devuelve un nuevo gestor de sentencia, o FALSE
en caso de error.
Ejemplo #1 Vincular un REF CURSOR en una llamada a un procedimiento almacenado de Oracle
// Precreación:
// 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, -1, OCI_B_CURSOR);
oci_execute($stid);
oci_execute($curs); // Ejecutar el REF CURSOR como un ide de sentencia normal
while (($row = oci_fetch_array($curs, OCI_ASSOC+OCI_RETURN_NULLS)) != false) {
echo $row['FIRST_NAME'] . "<br />\n";
}
oci_free_statement($stid);
oci_free_statement($curs);
oci_close($conn);
?>
Nota:
En versiones de PHP anteriores a la 5.0.0 se debe usar ocinewcursor() en su lugar. Este nombre aún puede usarse; se dejó como alias de oci_new_cursor() por razones de retrocompatibilidad. Sin embargo, este nombre es obsoleto y no se recomienda.