Précédent   Forum des professionnels en informatique > Java > Général Java > JDBC
JDBC Forum d'entraide sur l'API JDBC (Java Database Connectivity) et l'accès aux bases de données. Avant de poster -> FAQ JDBC
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 10/01/2012, 12h27   #1
Invité de passage
 
Inscription : août 2005
Messages : 11
Détails du profil
Informations forums :
Inscription : août 2005
Messages : 11
Points : 3
Points : 3
Par défaut Passer un UDT en paramètre d'une procédure stockée

Bonjour,

Depuis mon programme Java, je souhaite pouvoir passer une classe à une procédure stockée PL/SQL.
Je me suis inspiré de cet exemple .

Ma classe main
Code :
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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
 
 
public class Main {
    public static void main(String args[]) throws ClassNotFoundException {
 
        java.sql.Connection conn = null;
        try {
            conn = JDBCUtil.getDBConnection();
            CallableStatement statement;
            String sql;
            Array array;
 
 
//          mise en place du mapping
            java.util.Map map = conn.getTypeMap();
            map.put("SchemaName.PERSONNE", Class.forName("Personne"));
            conn.setTypeMap(map);
 
            Personne perso = new Personne();
            perso.setAge(44);
            perso.setNom("Toto");
            perso.setPrenom("Titi");
 
            sql = "{? = call PK_BDUWS_RNCPS.COLLECT_DCP(?)}";
			System.out.println("\n"+sql);
			statement = conn.prepareCall(sql);
			statement.registerOutParameter(1, Types.ARRAY, "T_RESULTAT_UNIT_TAB");
			statement.setObject(2, perso);
 
			statement.execute();
			array = statement.getArray(1);
			ArrayList<ResultatUnit> lst;
			try {
				lst = mapResultatUnitTab(array);
			} catch (Exception e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
 
			statement.close();
 
        } catch(SQLException s) {
            System.out.println(s);
        } finally {
            if(conn != null) {
                try {
                    conn.close();
                } catch(SQLException ignore) {}
            }
        }
    }
Et lorsque je l’exécute, j'obtiens ceci :
Citation:
{? = call PK_BDUWS_RNCPS.COLLECT_DCP(?)}
java.sql.SQLException: Echec de construction du descripteur: Invalid arguments
Avez vous une idée de ce qui pose problème ?

Merci pour votre aide

Korno
Kornoman est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 20/01/2012, 09h40   #2
in
Membre Expert
 
Avatar de in
 
Inscription : avril 2003
Messages : 1 609
Détails du profil
Informations personnelles :
Localisation : France, Finistère (Bretagne)

Informations forums :
Inscription : avril 2003
Messages : 1 609
Points : 1 564
Points : 1 564
Ta classe Personne est identique à celle de la FAQ ? (implements SQLData)

Ta table PERSONNE est dans le schema SchemaName ?

Tu peux montrer la signature de ta fonction PL/SQL ?
__________________
"If email had been around before the telephone was invented, people would have said, 'Hey, forget email! With this new telephone invention I can actually talk to people!"

Besoin d'une nouvelle méthode pour développer ? -> http://www.la-rache.com/
in est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 23/01/2012, 15h19   #3
Invité de passage
 
Inscription : août 2005
Messages : 11
Détails du profil
Informations forums :
Inscription : août 2005
Messages : 11
Points : 3
Points : 3
Merci pour ta réponse.
J'ai résolu mon problème en passant les attributs de ma classe un par un à la procédure stockée.
Kornoman est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 09h31.


 
 
 
 
Partenaires

Hébergement Web