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 :

org.hibernate.StaleStateException: Batch update returned unexpected row count from up


Sujet :

Hibernate Java

  1. #1
    Membre éprouvé
    Inscrit en
    Août 2008
    Messages
    1 596
    Détails du profil
    Informations forums :
    Inscription : Août 2008
    Messages : 1 596
    Par défaut org.hibernate.StaleStateException: Batch update returned unexpected row count from up
    Bonjour, j'ai mis une méthode pour enregister des id dans une table résultante :

    ma méthode :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    public void addRoletoUser(Long idu, Long idp){
    		Session session=HibernateUtil.getSessionFactory().getCurrentSession();
    		 session.beginTransaction();
    		 Role p = (Role)session.load(Role.class,idp);
    		 User u = (User)session.load(User.class, idu);
     
    		 u.getRoles.add(p);
    		 System.out.println("here");
    		 session.getTransaction().commit();
    	}
     
    }
    j'ai lancé un test avec :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    manager.addRoletoUser(new Long(14), new Long(5));
    sachant que dans ma base il y a un user avec id = 14 et un role avec le id = 5;
    mais il me donne l'erreur suivante : j'ai lu dans des articles que je dois mettre session.clear ou .flush mais ca n'a pas marché !

    j'ai remarque un truc bizarre dans ma console, c'est qu'il essai de modifier mon user alors c'est pas ca ce que j'ai demandé ?

    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
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    Hibernate: update USER set NOM=?, PRENOM=?, IDENTIFIANT=?, LOGIN=?, PASSWORD=?, ISACTIF=? where ID=?
    11:52:43,125 ERROR AbstractBatcher:61 - Exception executing batch: 
    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:195)
    	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:980)
    	at org.hibernate.impl.SessionImpl.managedFlush(SessionImpl.java:353)
    	at org.hibernate.transaction.JDBCTransaction.commit(JDBCTransaction.java:106)
    	at test.main(test.java:26)
    11:52:43,125 ERROR AbstractFlushingEventListener: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:195)
    	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:980)
    	at org.hibernate.impl.SessionImpl.managedFlush(SessionImpl.java:353)
    	at org.hibernate.transaction.JDBCTransaction.commit(JDBCTransaction.java:106)
    	at test.main(test.java:26)
    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:195)
    	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:980)
    	at org.hibernate.impl.SessionImpl.managedFlush(SessionImpl.java:353)
    	at org.hibernate.transaction.JDBCTransaction.commit(JDBCTransaction.java:106)
    	at test.main(test.java:26)
    vous avez une idée ?

  2. #2
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    100
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 100
    Par défaut
    Essayes de rajouter session.update(u)
    avant de faire le commit.

  3. #3
    Membre éprouvé
    Inscrit en
    Août 2008
    Messages
    1 596
    Détails du profil
    Informations forums :
    Inscription : Août 2008
    Messages : 1 596
    Par défaut
    ca donne le meme résultat, toujours la meme exception ?

Discussions similaires

  1. Réponses: 0
    Dernier message: 06/08/2014, 11h26
  2. Réponses: 20
    Dernier message: 13/10/2009, 17h31
  3. Réponses: 0
    Dernier message: 24/10/2008, 14h35
  4. Réponses: 1
    Dernier message: 10/10/2008, 10h39
  5. org.hibernate.hql.ast.QuerySyntaxError: unexpected token
    Par oughlad dans le forum Hibernate
    Réponses: 9
    Dernier message: 26/05/2006, 14h20

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