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
J'ai vérifié
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à
- 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()); }
Partager