Я определил хранимую процедуру PL / SQL, которая возвращает SYS_REFCURSOR
CREATE OR REPLACE PROCEDURE findByName
( res OUT SYS_REFCURSOR,
vName IN emp.name%type ) AS
BEGIN
OPEN res FOR
SELECT * FROM emp WHERE name = vName;
END findByName;
Затем я отображаю возвращенный курсор на объект Hibernate.
....
@Entity
@org.hibernate.annotations.NamedNativeQuery(name = "findByName", query = "call findByName(?, :vName)", callable = true, resultClass = Employee.class)
@Table(name = "EMP", schema = "WEBUI")
public class Employee implements java.io.Serializable {
....
Это метод DAO, который вызывает хранимую процедуру.
....
public Employee findByName(final String name) {
Session session = factory.getSession();
Query query = session.getNamedQuery("findByName");
query.setString("vName", name);
return (Employee) query.uniqueResult();
}
....
Это то, что я бы сделал, если бы вызывал хранимую процедуру из кода PL / SQL.
DECLARE
emp_cursor SYS_REFCURSOR;
emp_rec emp_cursor%ROWTYPE;
BEGIN
findByName
( res => emp_cursor,
vName => 'Timothy Jones');
FETCH emp_cursor
INTO emp_rec;
DBMS_OUTPUT.PUT_LINE(emp_rec.name);
CLOSE emp_cursor; -- close the cursor
END;
Я бы хотел подчеркнуть тот факт, что необходимо как-то закрыть emp_cursor
. В противном случае произошла бы утечка памяти.
Мой вопрос:
Как Hibernate справляется с этим? Он автоматически закрывает курсор после того, как объект Employee был получен, или программист должен закрыть его вручную?
Заранее спасибо.