我已经定义了一个返回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对象后是否会自动关闭游标,或者程序员是否必须手动关闭它?
提前致谢。
答案 0 :(得分:1)
您无法关闭此光标。 Hibernate引用要求您在使用存储过程进行查询时返回游标。
http://docs.jboss.org/hibernate/core/3.6/reference/en-US/html/querysql.html#sp_query
我的猜测是,hibernate会将返回的游标转换为用于迭代查询结果的ResultSet。如果ResultSet保持打开,那将是一个严重的休眠错误。 无论如何,当数据库连接池循环/关闭jdbc连接/语句时,此ResultSet在最坏的情况下关闭。