Bonjour,
cela fait une après midi que je suis bloqué sur une erreur

J'utilise postgres, jpa, hibernate

J'ai une table avec une clé composite. Je sauvegarde cette entité. Il y a une seule sauvegarde et j'ai le message d'erreur au moment où je sors de la méthode où je fait le save

Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
 
ERREUR: la valeur d(une clé dupliquée rompt la contrainte unique.... et plus loin Detail: la clé " (entity_id, commission_id)=(28, 4) " existe déjà
J'ai vérifié
- qu'il n'y a qu'un seul save
- le code de cette entité
- que la valeur n'existe pas en base

Je suis bloqué de bloqué. Pouvez vous m'aider ?

Voici le code

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
43
44
45
46
47
48
 
@Entity
@Table(name = "ENTITY_COMMISSION")
@NoArgsConstructor
@AllArgsConstructor
public class EntityCommission  implements Serializable {
 
    @EmbeddedId
    @NotNull
    private EntityCommissionId id = new EntityCommissionId();
 
    @ManyToOne
    @MapsId("commissionId")
    @NotNull
    private Commission commission;
 
    @ManyToOne
    @MapsId("entityId")
    @NotNull
    private EntityList entity;
 
 
 
@NoArgsConstructor
@AllArgsConstructor
@Embeddable
public class EntityCommissionId implements Serializable {
 
    private static final long serialVersionUID = 1L;
 
    @NotNull
    private Integer entityId;
    @NotNull
    private Integer commissionId;
 
 
 
 
List<Commission> commissions = commissionRepository.findByNameList(commissionNames);
EntityCommissionId entityCommissionId;
EntityCommission entityCommission;
for (Commission commission: commissions) {
	entityCommissionId = new EntityCommissionId(entityList.getId(), commission.getId());
	entityCommission = new EntityCommission(entityCommissionId, commission, entityList);
	entityCommission = entityCommissionRepository.save(entityCommission);
	entityList.getEntityCommissions().add(entityCommission);
	entityList.getCommissions().add(entityCommission.getCommission());
}