comment appeler une procédure stockée avec plusieurs paramètres à l'aide de gestionnaire d'entité

Nous sommes confrontés à un problème lors de l'appel de la procédure stockée à partir de l'application.
La base de données est oracle 10g
Ce proc a 2 paramètres d'entrée et les 2 paramètres de sortie.

Entrée 1:- DB-Liste
Entrée 2:- Chaîne

Sortie 1:-Encore un DB-Liste
Sortie 2:- Nombre

Lorsque nous essayons d'utiliser

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

Nous ne pouvons pas distinguer entre in paramètres et out paramètres.
Alors, comment devons-nous traiter à l'aide de cet.

Aussi,
Nous avons essayé d'utiliser appelable énoncé comme suit:

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

Nous obtenons le message d'erreur suivant:

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

Pouvez-vous veuillez donner quelques suggestions.

C'est le Gestionnaire de l'Entité que nous utilisons

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;
}
}

Ici est l'entrée dans le 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>
  • Je pense que le problème n'est pas avec la procédure stockée, est avec votre Gestionnaire d'entités.U peut coller votre code.
  • Salut @SajanChandran j'ai ajouté le code pour le gestionnaire de l'entité ainsi que la persistance.xml que nous utilisons
  • Nous avons essayé, à l'aide de déballer ainsi que de la session.doWork. Mais sa reste de nous donner le message d'erreur: java.lang.Exception: javax.ejb.EJBException: java.lang.ClassCastException: $Proxy66 ne peut pas être jeté à l'oracle.jdbc.OracleConnection.[/code]Cela se produit en particulier lorsque nous essayons d'obtenir la connexion pour le Descripteur de Tableau. ArrayDescriptor descripteur = ArrayDescriptor.createDescriptor(DB_LIST",callableStatement.getConnection());