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

JPA Java Discussion :

problème duplicate entry sur une primary key auto générée


Sujet :

JPA Java

  1. #1
    Membre du Club
    Inscrit en
    Septembre 2008
    Messages
    139
    Détails du profil
    Informations forums :
    Inscription : Septembre 2008
    Messages : 139
    Points : 50
    Points
    50
    Par défaut problème duplicate entry sur une primary key auto générée
    Bonjour à tous,

    J'essaie de persister une liste d'objet Contact qui est en OneToOne(cascade=CascadeType.ALL) avec un objet Adresse.

    Voici la fonction:
    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
     
    public void persist(List objects) throws VisionException {
            em.getTransaction().begin();
            try {
                for(Object object:objects){
                    em.persist(object);
                    System.out.println("persist: "+object);
                }
                em.getTransaction().commit();
            } catch (Exception e) {
                e.printStackTrace();
                em.getTransaction().rollback();
                throw new VisionPersistenceException("impossible de persister les objets ",e.getMessage());
            }
        }
    Ce code est exécuté par un SwingWorker. J'obtient l'exception suivante:
    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
     
    Exception in thread "AWT-EventQueue-0" javax.persistence.PersistenceException: Exception [TOPLINK-4002] (Oracle TopLink Essentials - 2.0.1 (Build b09d-fcs (12/06/2007))): oracle.toplink.essentials.exceptions.DatabaseException
    Internal Exception: com.mysql.jdbc.exceptions.MySQLIntegrityConstraintViolationException: Duplicate entry '87581' for key 1
    Error Code: 1062
    Call: INSERT INTO ADRESSE (ID, CP, VILLE, ADRESSE2, LATITUDE, ADRESSE1, LONGITUDE) VALUES (?, ?, ?, ?, ?, ?, ?)
            bind => [87581, cp, ville, adresse 2, null, adresse 1, null]
    Query: InsertObjectQuery(adresse 1 adresse 2 cp ville)
            at oracle.toplink.essentials.internal.ejb.cmp3.base.EntityManagerImpl.flush(EntityManagerImpl.java:353)
            at oracle.toplink.essentials.internal.ejb.cmp3.base.EJBQueryImpl.performPreQueryFlush(EJBQueryImpl.java:702)
            at oracle.toplink.essentials.internal.ejb.cmp3.base.EJBQueryImpl.executeReadQuery(EJBQueryImpl.java:347)
            at oracle.toplink.essentials.internal.ejb.cmp3.base.EJBQueryImpl.getResultList(EJBQueryImpl.java:478)
            at session.UpdaterActions2.actionPerformed(UpdaterActions2.java:113)
            at javax.swing.Timer.fireActionPerformed(Timer.java:271)
    [TopLink Warning]: 2009.10.16 09:58:30.173--UnitOfWork(1015506968)--Exception [TOPLINK-6014] (Oracle TopLink Essentials - 2.0.1 (Build b09d-fcs (12/06/2007))): oracle.toplink.essentials.exceptions.QueryException
    Exception Description: Objects cannot be written during a UnitOfWork, they must be registered.
    Query: InsertObjectQuery(adresse 1 adresse 2 cp ville)
            at javax.swing.Timer$DoPostEvent.run(Timer.java:201)
            at java.awt.event.InvocationEvent.dispatch(InvocationEvent.java:209)
            at java.awt.EventQueue.dispatchEvent(EventQueue.java:633)
            at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:296)
            at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:211)
            at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:201)
            at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:196)
            at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:188)
            at java.awt.EventDispatchThread.run(EventDispatchThread.java:122)
    Normalement j'ai aucun problème quand je persist q'un seul Contact à la fois.
    Edit: Mieux, je n'arrive à sauvegarder qu'une partie des objets.
    J'aimerais bien savoir pourquoi...

    Merci de m'aider
    A bientôt

  2. #2
    Membre du Club
    Inscrit en
    Septembre 2008
    Messages
    139
    Détails du profil
    Informations forums :
    Inscription : Septembre 2008
    Messages : 139
    Points : 50
    Points
    50
    Par défaut
    En fouillant un peu, j'ai constaté que je faisait appel à un entity manager qui est utilisé par un timer pour faire des requêtes. J'ai du donc créer un nouvel entity manager pour faire ce traitement. Cela fonctionne mais je n'arrive pas à faire un flush(), clear() et close() à la fin du traitement.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Duplicate entry '0.00' for key 'primary'
    Par apriliaz dans le forum Requêtes
    Réponses: 7
    Dernier message: 25/05/2012, 14h42
  2. [2.x] Setter sur une primary key de type string
    Par snipemi dans le forum Symfony
    Réponses: 3
    Dernier message: 29/08/2011, 17h40
  3. Problème de tri sur une PRIMARY KEY
    Par dudu92 dans le forum Oracle
    Réponses: 9
    Dernier message: 19/06/2007, 12h12
  4. auto-incrémentation sur une primary key avec sql server
    Par pops4 dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 24/05/2007, 14h24
  5. Problème de chaine sur une page HTML
    Par Kerod dans le forum Général JavaScript
    Réponses: 8
    Dernier message: 23/11/2004, 16h23

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