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

Langage Java Discussion :

problème appel à une fonction pl/sql


Sujet :

Langage Java

  1. #1
    Membre du Club
    Administrateur de base de données
    Inscrit en
    Juillet 2006
    Messages
    98
    Détails du profil
    Informations personnelles :
    Âge : 39

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Juillet 2006
    Messages : 98
    Points : 57
    Points
    57
    Par défaut problème appel à une fonction pl/sql
    Bonjour tout le monde. j'ai un petit problème lorsque je tente d'appler une fonction pl sql qui recoit un objet.

    Mon collègue as fait du code un peu avant de partir en vacance et je suis bloquer là où il était rendu.

    Voilà le java :

    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
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
     
            protected String recupQqchose(TestImpl oCarr,String psTri,String psDesc,int piPage,int piMaxPage) throws SQLException, 
                                                                                                                                   IOException, 
                                                                                                                                   ClassNotFoundException {
                String sResult = null;
                CallableStatement oAppelProcedure = moJCon.prepareCall("{ call ? := PKG_QQC.recupererTest(?,?,?,?,?,?) }");
                Map map = moJCon.getTypeMap();
     
                map.put("CARR_RECHERCHE",Class.forName("com.la.classe.serialiser"));
                oAppelProcedure.registerOutParameter(1,Types.INTEGER);
                oAppelProcedure.setObject(2,oCarr);
                oAppelProcedure.setString(3,psTri);
                oAppelProcedure.setString(4,psDesc);
                oAppelProcedure.setInt(5,piPage);
                oAppelProcedure.setInt(6,piMaxPage);
                oAppelProcedure.registerOutParameter(7,Types.CLOB);
                oAppelProcedure.execute();
                if(oAppelProcedure.getInt(1) >= 0){
                    if(oAppelProcedure.getClob(7) != null)
                        sResult = IOUtils.toString(oAppelProcedure.getClob(7).getCharacterStream());
                }
                if(sResult==null){
     
                }
                return sResult;
            }
    CARR_RECHERCHE ---> Type pl/sql qui correspond à mon objet de la classe TestImpl
    com.la.classe.serialiser --> classe qui extend de la classe de mon objet TestImpl et qui est Serializable


    paramètre du PL/SQL :
    (
    p_recherche IN carr_recherche,
    p_tri IN VARCHAR2,
    p_desc IN VARCHAR2,
    p_page IN INTEGER,
    p_maxpage IN INTEGER,
    p_xml OUT CLOB
    )
    RETURN NUMBER
    AS


    Et ça me dit toujours une erreur du genre

    07/08/06 15:54:43 java.sql.SQLException: ORA-06550: Ligne 1, colonne 13 :
    PLS-00306: numéro ou types d'arguments erronés dans appel à 'recupererTest'
    ORA-06550: Ligne 1, colonne 7 :
    PL/SQL: Statement ignored


    Quelqu'un a une idée pourquoi çca fonctionne pas?? Tout mes autres call a la BD sans objet fonctionne très bien..

    Merci

    Bye

  2. #2
    Membre confirmé Avatar de miloux32
    Profil pro
    Inscrit en
    Juillet 2003
    Messages
    545
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2003
    Messages : 545
    Points : 565
    Points
    565
    Par défaut
    A vu de nez : Y'a pas le meme nombre d'argument et les types sont pas les bons ...

  3. #3
    Expert éminent sénior
    Avatar de sinok
    Profil pro
    Inscrit en
    Août 2004
    Messages
    8 765
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Août 2004
    Messages : 8 765
    Points : 12 977
    Points
    12 977
    Par défaut
    Vas faire un tour par là: http://java.developpez.com/faq/jdbc/...lablestatement

    Tu verras que la chaine contenant le call est mal formée.

  4. #4
    Membre du Club
    Administrateur de base de données
    Inscrit en
    Juillet 2006
    Messages
    98
    Détails du profil
    Informations personnelles :
    Âge : 39

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Juillet 2006
    Messages : 98
    Points : 57
    Points
    57
    Par défaut
    hum tout mes autres call à la bd sont formés de cette façon et fonctionne très bien...

    je n'ai jamais vue de call comme ils sont décrits dans la FAQ que tu m'as proposé

Discussions similaires

  1. Appeler une fonction pl/sql dans vb6
    Par pupucette dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 05/06/2012, 16h55
  2. Problème dans une fonction PL/SQL
    Par jnayna86 dans le forum PL/SQL
    Réponses: 3
    Dernier message: 19/04/2008, 13h28
  3. Réponses: 0
    Dernier message: 27/11/2007, 17h17
  4. Réponses: 7
    Dernier message: 10/09/2005, 16h49
  5. [DLL] problème pour appeler une fonction d'une DLL
    Par bigboomshakala dans le forum MFC
    Réponses: 34
    Dernier message: 19/07/2004, 11h30

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