私はMySqlを使用しており、呼び出すクエリは次のようになります:
call SPGetChart (idNumber, nameChart);
私は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 クラスはストアド プロシージャをサポートするようになりました。
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();