Hibernate会自动关闭引用光标吗?

时间:2012-01-27 15:04:07

标签: hibernate plsql

我已经定义了一个返回SYS_REFCURSOR

的PL / SQL存储过程
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对象后是否会自动关闭游标,或者程序员是否必须手动关闭它?

提前致谢。

1 个答案:

答案 0 :(得分:1)

您无法关闭此光标。 Hibernate引用要求您在使用存储过程进行查询时返回游标。

http://docs.jboss.org/hibernate/core/3.6/reference/en-US/html/querysql.html#sp_query

我的猜测是,hibernate会将返回的游标转换为用于迭代查询结果的ResultSet。如果ResultSet保持打开,那将是一个严重的休眠错误。 无论如何,当数据库连接池循环/关闭jdbc连接/语句时,此ResultSet在最坏的情况下关闭。