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>
denke ich das Problem nicht mit der gespeicherten Prozedur ist, ist mit dem Entity Manager.Can u Ihre vollständigen Code einzufügen. –
Hallo @SajanChandran Ich habe den Code für den Entity Manager sowie die persistance.xml, die wir verwenden, –
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()); –