Sobes.tech
Назад к вопросам
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 с нужным запросом, а вызывающий код читает из него данные.