在通用 DAO 中使用 Hibernate 调用存储过程的最佳方法是啥?

Posted

技术标签:

【中文标题】在通用 DAO 中使用 Hibernate 调用存储过程的最佳方法是啥?【英文标题】:What's the best way to calling a Stored Procedure using Hibernate in a Generic DAO?在通用 DAO 中使用 Hibernate 调用存储过程的最佳方法是什么? 【发布时间】:2012-10-25 16:52:00 【问题描述】:

我正在使用 mysql,我要调用的查询如下:

call SPGetChart (idNumber, nameChart);

【问题讨论】:

【参考方案1】:

使用实体管理器

   Query query=getEntityManager().
                           createNativeQuery("BEGIN SPGetChart(:id, :name); END;");
   query.setParameter("id", idValue);
   query.setParameter("name", nameChart);

   query.executeUpdate();

通过 EntityManager 使用连接:

   Connection con = ((SessionImpl) getEntityManager().getDelegate()).connection();
   CallableStatement callableStatement = cc.prepareCall("call SPGetChart (?,?)");

   callableStatement.setInt(1, idValue);
   callableStatement.setString(2, nameChart);
   callableStatement.execute();

使用会话:

Query query = session.createSQLQuery("CALL SPGetChart (:id, :name)")
               .setParameter("id", idValue)
                   .setParameter("name", nameChart);
query.executeUpdate();

【讨论】:

我正在使用另一种方法,请看:jsfiddle.net/2TZA2 我没有会话或 getSession。在数据源中我找不到“createSQLQuery”这个文件应该如何更改? @HelioBentzen:我看到你有getEntityManager。我更新了答案以使用相同的答案。 我需要做一些测试才能说出来,但不是错误。谢谢。等我说完就在这儿说。【参考方案2】:

我知道这是一个老问题,但对于那些现在发现这个问题的人来说,EntityManager 类现在支持存储过程。

StoredProcedureQuery query = getEntityManager().createStoredProcedureQuery("SPGetChart");

query.registerStoredProcedureParameter(1, Integer.class, ParameterMode.IN);
query.registerStoredProcedureParameter(2, String.class, ParameterMode.IN);

query.setParameter(1, idValue);
query.setParameter(2, nameChart);
query.execute();

【讨论】:

以上是关于在通用 DAO 中使用 Hibernate 调用存储过程的最佳方法是啥?的主要内容,如果未能解决你的问题,请参考以下文章

hibernate 通用 dao 重载 removeById

Hibernate 通用 DAO 搜索

Spring 3,带有通用 DAO 的 Hibernate 4 AutoWired sessionFactory

通用 DAO hibernate 4 + spring 4 和异常处理

正确实现一个 dao 类来管理事务

通用Hibernate-Dao