Пожалуйста, измените название, если вы знаете лучший, потому что я действительно не знаю, как выразить проблему.
У меня есть три класса:
@Entity
public class User {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id")
private Integer id;
@NotNull
@Size(min = 1, max = 45)
@Column(name = "name")
private String name;
@JoinTable(name = "usuer_has_contact", joinColumns = {
@JoinColumn(name = "user_id", referencedColumnName = "id")}, inverseJoinColumns = {
@JoinColumn(name = "contact_id", referencedColumnName = "id")})
@ManyToMany(cascade = CascadeType.ALL)
private List<Contato> contactList;
//Getters and Setters
}
DB Table:
Table Name: User
Columns: id (int pk), name (varchar(45) not null).
@Entity
private class Contact {
@EmbeddedId
protected UserHasContact userHasContact;
@NotNull
@Size(min = 1, max = 45)
@Column(name = "value")
private String value;
@ManyToMany(mappedBy = "contactList")
private List<User> userList;
//Getters and Setters
}
DB Table:
Table Name: Contact
Columns: id (int pk), value (varchar(45) not null).
@Embeddable
private class UserHasContact {
@NotNull
@Column(name = "id")
private Integer id;
//Getters and Setters
}
DB Table:
Table Name: UserHasContact
Columns: userId (int pk), contactId (int pk).
То, что я пытаюсь сделать, это сохранять все, когда я сохраняю самого пользователя.Например:
User user = new User();
user.setContactList(new ArrayList<Contact>());
Contact contact = new Contact();
contact.setValue("555-5555");
user.getContactList().add(contact);
// Here I'd call another class, passing User so it would only do a
// entityManager.persist(user), and it would persist it all and
// take care of all tables for me. What I don't want to do is to
// fill up the values myself, I want let JPA do it for me.
Я ожидал сохранить после этого, но он говорит, что contactId имеет значение NULL и не может быть NULL.Что я могу сделать?