Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/349.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 什么';在通用DAO中使用Hibernate调用存储过程的最佳方法是什么?_Java_Mysql_Hibernate_Genericdao - Fatal编程技术网

Java 什么';在通用DAO中使用Hibernate调用存储过程的最佳方法是什么?

Java 什么';在通用DAO中使用Hibernate调用存储过程的最佳方法是什么?,java,mysql,hibernate,genericdao,Java,Mysql,Hibernate,Genericdao,我正在使用MySql,我要调用的查询如下: call SPGetChart (idNumber, nameChart); 使用EntityManager Query query=getEntityManager(). createNativeQuery("BEGIN SPGetChart(:id, :name); END;"); query.setParameter("id", idValue); query.setPar

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

call SPGetChart (idNumber, nameChart);
使用EntityManager

   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();
使用EntityManager

   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();

我知道这是一个老问题,但是对于那些现在发现这个问题的人来说,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();

我知道这是一个老问题,但是对于那些现在发现这个问题的人来说,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();

我正在使用另一种方法,看这个:我没有会话或getSession。在数据源中我找不到“createSQLQuery”如何更改此文件?@HelioBentzen:我看到您有
getEntityManager
。我更新了答案以使用相同的答案。我需要做一些测试来说明这一点,但不要出错。谢谢当我结束的时候,我会在这里说,我正在使用另一种方法,看这个:我没有会话或getSession。在数据源中我找不到“createSQLQuery”如何更改此文件?@HelioBentzen:我看到您有
getEntityManager
。我更新了答案以使用相同的答案。我需要做一些测试来说明这一点,但不要出错。谢谢等我讲完,我会在这里说。