2012-11-06 3 views
6

Wir stehen vor einem Problem beim Aufruf der gespeicherten Prozedur aus der Anwendung. Die Datenbank ist oracle 10g Dieser Prozess hat 2 Eingangsparameter und 2 Ausgangsparameter.wie gespeicherte Prozedur mit mehreren Ein- und Aus-Parameter mit Entitätsmanager aufrufen

Eingang 1: - DB-List Eingang 2: - String

Ausgang 1: DB-wieder-Liste Ausgang 2: - Anzahl

Wenn wir

Query q = session.createSQLQuery("{call proc_name(?,?,?,?)}"); 
versuchen, zu verwenden

Wir können nicht zwischen in Parametern und out Parametern unterscheiden. Also wie sollen wir damit umgehen?

Auch Wir haben versucht, aufrufbar Anweisung wie folgt zu verwenden:

Session session = (Session) getEntityManager().getDelegate(); 
SessionImpl sessionImpl = ((SessionImpl) getEntityManager().getDelegate()); 
Connection cc = sessionImpl.connection(); 
CallableStatement callableStatement = null; 

callableStatement = cc.prepareCall("{call proc_name(?,?,?,?)}"); 
ArrayDescriptor descriptor = ArrayDescriptor.createDescriptor("DB_LIST",callableStatement.getConnection()); 
ARRAY paramArray = new ARRAY(descriptor, callableStatement.getConnection(), array); 
callableStatement.setArray(1, paramArray); 
callableStatement.setString(2, "N"); 
callableStatement.registerOutParameter(3, OracleTypes.ARRAY, "DB_RETURN_LIST"); 
callableStatement.registerOutParameter(4, Types.INTEGER); 
// executing the query 
callableStatement.execute(); 

Wir haben die folgende Fehlermeldung erhalten:

javax.ejb.EJBException: java.lang.ClassCastException: 
$Proxy50 cannot be cast to oracle.jdbc.OracleConnection 

Können Sie einige Anregungen geben Sie bitte.

Dies ist der Entity-Manager, die wir

public abstract class GenericDAO<T, ID extends Serializable> implements IGenericDAO<T, ID> { 
private final Class<T> persistentClass; 
@PersistenceContext(unitName = "firstPersistenceUnit") 
@Produces 
private EntityManager entityManager; 

public void setEntityManager(final EntityManager entityManager) throws DataAccessException { 
this.entityManager = entityManager; 
} 

public EntityManager getEntityManager() throws DataAccessException { 
return entityManager; 
} 
} 

Hier ist der Eintrag in der Persistance.xml

<?xml version="1.0" encoding="UTF-8"?> 
<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"> 
<persistence-unit name="firstPersistenceUnit"> 
<provider>org.hibernate.ejb.HibernatePersistence</provider> 
<jta-data-source>java:jboss/firstDataSource</jta-data-source> 
<class>com.domain.Branch</class> 
<exclude-unlisted-classes>true</exclude-unlisted-classes> 
<shared-cache-mode>ENABLE_SELECTIVE</shared-cache-mode> 
<validation-mode>AUTO</validation-mode> 
    <properties> 
     <property name="hibernate.dialect" value="org.hibernate.dialect.Oracle10gDialect" /> 
     <property name="hibernate.connection.driver_class" value="oracle.jdbc.driver.OracleDriver" /> 
     <property name="hibernate.show_sql" value="true"/> 
     <property name="hibernate.format_sql" value="true"/> 
    </properties> 
</persistence-unit> 

<persistence-unit name="secondPersistenceUnit"> 
<provider>org.hibernate.ejb.HibernatePersistence</provider> 
<jta-data-source>java:jboss/secondDataSource</jta-data-source> 
<class>com.domain.PocJeeCounty</class> 
<exclude-unlisted-classes>true</exclude-unlisted-classes> 
<shared-cache-mode>ENABLE_SELECTIVE</shared-cache-mode> 
<validation-mode>AUTO</validation-mode> 
    <properties> 
     <property name="hibernate.dialect" value="org.hibernate.dialect.Oracle10gDialect" /> 
     <property name="hibernate.connection.driver_class" value="oracle.jdbc.driver.OracleDriver" /> 
     <property name="hibernate.show_sql" value="true"/> 
     <property name="hibernate.format_sql" value="true"/> 
    </properties> 
</persistence-unit> 
</persistence> 
+0

denke ich das Problem nicht mit der gespeicherten Prozedur ist, ist mit dem Entity Manager.Can u Ihre vollständigen Code einzufügen. –

+0

Hallo @SajanChandran Ich habe den Code für den Entity Manager sowie die persistance.xml, die wir verwenden, –

+0

Wir haben dies mit Unwrap sowie session.doWork versucht. Aber es gibt immer noch den Fehler: - java.lang.Exception: javax.ejb.EJBException: java.lang.ClassCastException: $ Proxy66 kann nicht in oracle.jdbc.OracleConnection umgewandelt werden. [/ Code] Dies geschieht speziell, wenn wir versuchen Sie, die Verbindung für Array Descriptor zu erhalten. ArrayDescriptor descriptor = ArrayDescriptor.createDescriptor (DB_LIST ", callableStatement.getConnection()); –

Antwort

2

Dont verwenden zweite Art und Weise verwenden, stattdessen erstellen und mit Hilfe von Abfrage und Abfrageparameter definieren @ NamedStoredProcedureQuery und @ StoredProcedureParameter. Im Anschluss an den Code für Ihre Anforderung ist

@NamedStoredProcedureQuery( 
    name="PROC_NAME", 
    procedureName="proc_name", 
    returnsResultSet=true/false, 
    parameters={ 
     @StoredProcedureParameter(queryParameter="param1",name="p1",direction=Direction.IN,type=Integer.class), 
     @StoredProcedureParameter(queryParameter="param2",name="p2",direction=Direction.IN,type=Timestamp.class), 
     @StoredProcedureParameter(queryParameter="param3",name="p3",direction=Direction.OUT,type=String.class), 
     @StoredProcedureParameter(queryParameter="param4",name="p4",direction=Direction.OUT,type=Integer.class) 
    } 
    ) 

und verwenden em.createNativeQuery() -Methode