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 ?