Я пытаюсь отобразить следующее:
public class Person{
...
@ManyToMany(cascade = { CascadeType.PERSIST, CascadeType.MERGE })
@JoinTable(name = "person_categories", joinColumns = @JoinColumn(name = "personId"), inverseJoinColumns = @JoinColumn(name = "categoryId"))
private Set<Category> categories
...
}
public class Category {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "categoryId")
private Integer id;
@Column(unique = true)
private Sting name
...
}
Когда я пытаюсь сохранить объект Person, категории вставляются, но дубликаты сохраняются в таблице. Как я могу гарантировать, что каждая категория уникальна в своей таблице и при этом поддерживает транзитивное постоянство? Я попытался сделать столбец имени уникальным, но это помогло только путем выдачи ошибок ограничения.