Problème d'utilisation d'un bean avec Oracle

Problème d'utilisation d'un bean avec Oracle - Java - Programmation

Marsh Posté le 10-11-2006 à 09:43:07    

Bonjour,
J'essaie actuellement de tester une application basée sur les EJB : en fait, un des exemples integrés au logiciel Jonas. J'ai donc d'abord installé Jonas (ainsi que le JDK et Ant), configuré mes variables d'environnement (CLASSPATH, ...), puis essayé d'executer les exemples d'application stockés dans Jonas. Le Session Bean (ClientOp) marche bien, mais l'EntityBean (ClientAccount) pose un problème, au niveau de la relation avec la base de données. La connexion est bien établie (j'ai bien mis dans mon CLASSPATH un .jar contenant le driver), c'est au niveau de la manipulation des données que le problème se pose.
Voici la partie du code à executer qui pose problème :

Code :
  1. // Create a first Account
  2. System.out.println("Creating a new Account in database" );
  3. System.out.println("7" );
  4. Account a1 = null;
  5. try {
  6. a1 = home.create(109, "John Smith", 0);
  7. } catch (Exception e) {
  8. System.out.println("Ici" );
  9. System.err.println("Cannot create Account: " + e);
  10. System.exit(2);
  11. }


Et l'erreur engendrée :

Code :
  1. Creating a new Account in database
  2. Cannot create Account: javax.ejb.CreateException: java.sql.SQLException: ORA-000
  3. 01: violation de contrainte unique (SYSTEM.SYS_C003021)


Alors que, pourtant, la table ne contient pas de t-uples ayant déjà l'identifiant 109. (J'ai regardé son état avant l'execution du bean, et l'erreur se produit même si la table est vide).
Le fichier de remplissage de la table :

Code :
  1. drop table accountsample_;
  2. create table accountsample_ (
  3. accno_ integer primary key,
  4. customer_ varchar(30),
  5. balance_ number(15, 4)
  6. );
  7. insert into accountsample_ values(101, 'Antoine de St Exupery', 200.00);
  8. insert into accountsample_ values(102, 'alexandre dumas fils', 400.00);
  9. insert into accountsample_ values(103, 'conan doyle', 500.00);
  10. insert into accountsample_ values(104, 'alfred de musset', 100.00);
  11. insert into accountsample_ values(105, 'phileas lebegue', 350.00);
  12. insert into accountsample_ values(106, 'alphonse de lamartine', 650.00);


Quelqu'un aurait-il la solution à ce problème ?
Merci d'avance.

Reply

Marsh Posté le 10-11-2006 à 09:43:07   

Reply

Sujets relatifs:

Leave a Replay

Make sure you enter the(*)required information where indicate.HTML code is not allowed