array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'ru', ), 'this' => array ( 0 => 'function.oci-new-cursor.php', 1 => 'oci_new_cursor', ), 'up' => array ( 0 => 'ref.oci8.php', 1 => 'OCI8 Функции', ), 'prev' => array ( 0 => 'function.oci-new-connect.php', 1 => 'oci_new_connect', ), 'next' => array ( 0 => 'function.oci-new-descriptor.php', 1 => 'oci_new_descriptor', ), 'alternatives' => array ( ), 'source' => array ( 'lang' => 'ru', 'path' => 'reference/oci8/functions/oci-new-cursor.xml', ), ); $setup["toc"] = $TOC; $setup["toc_deprecated"] = $TOC_DEPRECATED; $setup["parents"] = $PARENTS; manual_setup($setup); ?>
(PHP 5, PHP 7, PHP 8, PECL OCI8 >= 1.1.0)
oci_new_cursor — Возвращает идентификатор созданного курсора
Создаёт новый курсор для указанного соединения и возвращает его идентификатор.
connection
Идентификатор соединения с сервером Oracle, возвращаемый функцией oci_connect() или oci_pconnect().
Возвращает указатель на новое выражение или false
в случае возникновения ошибки.
Пример #1 Привязка REF CURSOR в вызове хранимых процедур Oracle
<?php
// Предварительная подготовка:
// создайте или замените процедуру myproc(myrc out sys_refcursor) как
// 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); // Выполняет REF CURSOR как обычный идентификатор выражения
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);
?>