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 :

Problème d'ordre d'ajout


Sujet :

Hibernate Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de ploxien
    Inscrit en
    Février 2006
    Messages
    467
    Détails du profil
    Informations personnelles :
    Âge : 40

    Informations forums :
    Inscription : Février 2006
    Messages : 467
    Par défaut Problème d'ordre d'ajout
    Hello,

    J'ai un souci d'ajout dans ma base, je pense que cela vient du fait qu'il essaie de faire un lien vers un élément pas encore créé...

    Pour résumer, j'ai une classe DecapMessage et une classe EncapMessage.

    Dans ma classe DecapMessage, j'ai une variable qui pointe vers EncapMessage.

    Mon élément de type DecapMessage existe, et j'y ajoute un EncapMessage. Lorsque je fais un saveOrUpdate, j'ai l'erreur suivante:
    org.hibernate.StaleStateException: Batch update returned unexpected row count from update: 0 actual row count: 0 expected: 1
    Mon mapping:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <one-to-one name="encapMessage" class="ch.ff.adsf.eascia.decap.EncapMessage" cascade="all"></one-to-one>
    Et je fais un saveOrUpdate sur mon DecapMessage

    Quel est mon problème? Je ne comprends pas...

    log complet:
    org.hibernate.StaleStateException: Batch update returned unexpected row count from update: 0 actual row count: 0 expected: 1
    at org.hibernate.jdbc.BatchingBatcher.checkRowCount(BatchingBatcher.java:93)
    at org.hibernate.jdbc.BatchingBatcher.checkRowCounts(BatchingBatcher.java:79)
    at org.hibernate.jdbc.BatchingBatcher.doExecuteBatch(BatchingBatcher.java:58)
    at org.hibernate.jdbc.AbstractBatcher.executeBatch(AbstractBatcher.java:193)
    at org.hibernate.engine.ActionQueue.executeActions(ActionQueue.java:230)
    at org.hibernate.engine.ActionQueue.executeActions(ActionQueue.java:141)
    at org.hibernate.event.def.AbstractFlushingEventListener.performExecutions(AbstractFlushingEventListener.java:296)
    at org.hibernate.event.def.DefaultFlushEventListener.onFlush(DefaultFlushEventListener.java:27)
    at org.hibernate.impl.SessionImpl.flush(SessionImpl.java:905)
    at org.hibernate.impl.SessionImpl.managedFlush(SessionImpl.java:345)
    at org.hibernate.transaction.JDBCTransaction.commit(JDBCTransaction.java:106)
    at ch.ff.asdf.eascia.Main.main(Main.java:78)
    10:02:54 [DEBUG] [org.hibernate.jdbc.AbstractBatcher] (logClosePreparedStatement:317): about to close PreparedStatement (open PreparedStatements: 1, globally: 1)
    10:02:54 [DEBUG] [org.hibernate.jdbc.AbstractBatcher] (closePreparedStatement:459): closing statement
    10:02:54 [ERROR] [org.hibernate.event.def.AbstractFlushingEventListener] (performExecutions:299): Could not synchronize database state with session
    org.hibernate.StaleStateException: Batch update returned unexpected row count from update: 0 actual row count: 0 expected: 1
    at org.hibernate.jdbc.BatchingBatcher.checkRowCount(BatchingBatcher.java:93)
    at org.hibernate.jdbc.BatchingBatcher.checkRowCounts(BatchingBatcher.java:79)
    at org.hibernate.jdbc.BatchingBatcher.doExecuteBatch(BatchingBatcher.java:58)
    at org.hibernate.jdbc.AbstractBatcher.executeBatch(AbstractBatcher.java:193)
    at org.hibernate.engine.ActionQueue.executeActions(ActionQueue.java:230)
    at org.hibernate.engine.ActionQueue.executeActions(ActionQueue.java:141)
    at org.hibernate.event.def.AbstractFlushingEventListener.performExecutions(AbstractFlushingEventListener.java:296)
    at org.hibernate.event.def.DefaultFlushEventListener.onFlush(DefaultFlushEventListener.java:27)
    at org.hibernate.impl.SessionImpl.flush(SessionImpl.java:905)
    at org.hibernate.impl.SessionImpl.managedFlush(SessionImpl.java:345)
    at org.hibernate.transaction.JDBCTransaction.commit(JDBCTransaction.java:106)
    at ch.ff.asdf.eascia.Main.main(Main.java:78)
    Exception in thread "main" org.hibernate.StaleStateException: Batch update returned unexpected row count from update: 0 actual row count: 0 expected: 1
    at org.hibernate.jdbc.BatchingBatcher.checkRowCount(BatchingBatcher.java:93)
    at org.hibernate.jdbc.BatchingBatcher.checkRowCounts(BatchingBatcher.java:79)
    at org.hibernate.jdbc.BatchingBatcher.doExecuteBatch(BatchingBatcher.java:58)
    at org.hibernate.jdbc.AbstractBatcher.executeBatch(AbstractBatcher.java:193)
    at org.hibernate.engine.ActionQueue.executeActions(ActionQueue.java:230)
    at org.hibernate.engine.ActionQueue.executeActions(ActionQueue.java:141)
    at org.hibernate.event.def.AbstractFlushingEventListener.performExecutions(AbstractFlushingEventListener.java:296)
    at org.hibernate.event.def.DefaultFlushEventListener.onFlush(DefaultFlushEventListener.java:27)
    at org.hibernate.impl.SessionImpl.flush(SessionImpl.java:905)
    at org.hibernate.impl.SessionImpl.managedFlush(SessionImpl.java:345)
    at org.hibernate.transaction.JDBCTransaction.commit(JDBCTransaction.java:106)
    at ch.ff.asdf.eascia.Main.main(Main.java:78)

  2. #2
    Membre éclairé Avatar de ploxien
    Inscrit en
    Février 2006
    Messages
    467
    Détails du profil
    Informations personnelles :
    Âge : 40

    Informations forums :
    Inscription : Février 2006
    Messages : 467
    Par défaut
    J'ai résolu le problème en supprimant le cascade et en sauvant le encapMessage avant le decapMessage.

    Mais y a-t-il mieux?

  3. #3
    Inactif  
    Profil pro
    Inscrit en
    Mai 2006
    Messages
    2 189
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : Suisse

    Informations forums :
    Inscription : Mai 2006
    Messages : 2 189
    Par défaut
    si tu supprimes le cascade alors tu auras des problèmes lors de la suppression (et pourquoi tu n'utilises pas les annotations ?)

  4. #4
    Membre confirmé
    Profil pro
    Étudiant
    Inscrit en
    Avril 2009
    Messages
    52
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2009
    Messages : 52
    Par défaut
    Bonjour,

    j'ai le même problème mais j'ai pas compris comment je dois procéder avec les annotations.

    Merci

  5. #5
    Membre confirmé
    Inscrit en
    Avril 2008
    Messages
    76
    Détails du profil
    Informations forums :
    Inscription : Avril 2008
    Messages : 76
    Par défaut
    Bonjour,

    Ce genre d'erreurs n'est qu'une conséquence d'une autre erreur.

    Si tu veux avoir la cause première lors de ton ajout, reproduit le bug en mettant dans tes paramètres de configuration hibernate

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <showsql>true</showsql>
    Ensuite tu avance pas à pas lors de ton ajout, pour arriver au moment precis ou l'insertion se fait en base.

    J'ai souvent eu ce genre d'erreur indéchiffrable mais quand on arrive à capter le moment meme de l'insertion on obtient un message très explicite
    de l'origine du problème avec la colonne concerné et le pourquoi.

    Tiens nous au courant.

Discussions similaires

  1. Problème d'ordre de remplissage de table
    Par matana dans le forum Langage SQL
    Réponses: 6
    Dernier message: 24/03/2006, 16h37
  2. [SimpleXML] Problème sur simpleXML pour ajouter de nouveaux noeuds
    Par Shandler dans le forum Bibliothèques et frameworks
    Réponses: 1
    Dernier message: 26/02/2006, 13h55
  3. [Client mail] Problème lors de l'ajout des comptes
    Par Leobaillard dans le forum Web & réseau
    Réponses: 9
    Dernier message: 19/11/2005, 17h12
  4. Réponses: 3
    Dernier message: 18/08/2005, 11h57
  5. [XSLT]Problèmes d'ordre de lecture et d'écriture
    Par leup dans le forum XSL/XSLT/XPATH
    Réponses: 2
    Dernier message: 11/07/2005, 10h36

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