Назад к вопросам
Middle
26
Как через курсор (REF CURSOR) возвращать значение из процедуры?
Компании, где спрашивали
AltDev
Ответ от нейросети
sobes.tech AI
В Oracle PL/SQL для возврата набора строк из процедуры часто используют REF CURSOR. Это указатель на результат запроса, который можно открыть внутри процедуры и вернуть вызывающему коду.
Пример процедуры с OUT параметром типа REF CURSOR:
CREATE OR REPLACE PROCEDURE get_employees(p_dept_id IN NUMBER, p_refcur OUT SYS_REFCURSOR) AS
BEGIN
OPEN p_refcur FOR
SELECT employee_id, first_name, last_name
FROM employees
WHERE department_id = p_dept_id;
END;
/
Вызов из PL/SQL блока:
DECLARE
rc SYS_REFCURSOR;
emp_id employees.employee_id%TYPE;
fname employees.first_name%TYPE;
lname employees.last_name%TYPE;
BEGIN
get_employees(10, rc);
LOOP
FETCH rc INTO emp_id, fname, lname;
EXIT WHEN rc%NOTFOUND;
DBMS_OUTPUT.PUT_LINE(emp_id || ' ' || fname || ' ' || lname);
END LOOP;
CLOSE rc;
END;
/
Таким образом, процедура открывает REF CURSOR с нужным запросом, а вызывающий код читает из него данные.