IdentifiantMot de passe
Loading...
Mot de passe oubli� ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les r�ponses en temps r�el, voter pour les messages, poser vos propres questions et recevoir la newsletter

Hibernate Java Discussion :

Valeur de retour d'une fonction plsql


Sujet :

Hibernate Java

  1. #1
    Membre �clair�

    Inscrit en
    Ao�t 2002
    Messages
    302
    D�tails du profil
    Informations personnelles :
    �ge : 43

    Informations forums :
    Inscription : Ao�t 2002
    Messages : 302
    Par d�faut Valeur de retour d'une fonction plsql
    Bonjour � tous,
    J'ai une function plsql que j'arrive � ex�cuter depuis hibernate mais j'arrive pas � r�cup�rer la valeur de retour.
    J'ai bien suivi le poste http://www.developpez.net/forums/d62...edure-stockee/ mais quand je met
    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    3
    4
    5
    6
    BigDecimal test = new BigDecimal("0");
    		String result = "";
    		Query q = getHibernateTemplate().getSessionFactory()
    				.getCurrentSession().getNamedQuery(PR_APPLY).setBigDecimal(
    						"test", test).setString("result", result);
    		q.list();
    J'ai l'erreur suivante
    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    Could not extract result set metadata
    mais quand je fais j'arrive bien � ex�cuter la fonction mais pas moyen de recuperer le r�sultat.
    Voila l'ent�te de ma fonction :
    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    FUNCTION pr_apply(msgErr IN OUT VARCHAR2) RETURN NUMBER IS
    Merci d'avance pour votre aide

  2. #2
    Membre �clair�

    Inscrit en
    Ao�t 2002
    Messages
    302
    D�tails du profil
    Informations personnelles :
    �ge : 43

    Informations forums :
    Inscription : Ao�t 2002
    Messages : 302
    Par d�faut
    Aucune suggestion ? Aucune piste ?

  3. #3
    Membre Expert
    Inscrit en
    Ao�t 2009
    Messages
    1 073
    D�tails du profil
    Informations forums :
    Inscription : Ao�t 2009
    Messages : 1 073
    Par d�faut
    Bonjour,

    Mon exp�rience d'hibernate est limit�e � Oracle, mais pour le coup effectivement pour que tu puisses obtenir le r�sultat il ne faut pas retourner un Number mais un SYS_REFCURSOR.
    Si tu calcules ton Resultat (NUMBER), tu as juste � la fin de ta fonction SQL � faire :
    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
     
    FONCTION pr_apply (msgErr IN OUT VARCHAR2) RETURN NUMBER IS
     
    curs SYS_REFCURSOR;
     
    BEGIN
    // Ton code actuel
     
      OPEN curs FOR
        SELECT msgErr FROM DUAL;
     
      RETURN curs;
     
    // Gestion d'une éventuelle exception avec un autre retour similaire
     
    END pr_apply;
    EDIT : mise en forme

Discussions similaires

  1. R�ponses: 4
    Dernier message: 19/01/2009, 11h12
  2. R�ponses: 5
    Dernier message: 14/06/2008, 13h30
  3. R�ponses: 5
    Dernier message: 13/06/2007, 15h05
  4. R�ponses: 5
    Dernier message: 18/09/2006, 14h17
  5. recuperer en php le retour d'une fonction plsql
    Par gismoblue dans le forum Langage SQL
    R�ponses: 1
    Dernier message: 14/03/2006, 16h39

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo