Исключение: com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException: столбец dog_id не может быть пустым
У меня есть две сущности с отношениями родитель-ребенок. Собака, очевидно, родитель, а щенок - ребенок. Как мне сохранить собак и щенков без ошибок?
@XmlRootElement(name = "dog")
@Entity
@Table(name = "dog", catalog = "zoo")
public class Dog{
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Integer id;
@Column(name = "dogname")
private String dogName;
@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY, mappedBy = "Dog")
private Set<Puppy> puppies;
...// getters and setters
@XmlElementWrapper(name = "puppies")
@XmlElement(name = "puppy")
public Set<Puppy> getPuppy() {
return this.puppies;
}
}
@Entity
@Table(name = "puppy", catalog = "zoo")
public class Puppy{
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Integer id;
@Column(name = "puppyname")
private String puppyName;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "dog_id", nullable = false)
private Dog dog;
...// getters and setters
}
По сути, пользователь переходит в Dog- со своими щенками - в качестве элемента jaxb.
@POST
@Consumes({MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON})
@Produces({MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON})
public Response createDog(JAXBElement<Dog> jaxbDog) {
Dog dog = jaxbDog.getValue();
dogDao.save(dog);
return Response.status(Response.Status.OK).build();
}
Мой вопрос, опять же, как я могу заставить щенков видеть dog_id родительской собаки?
1 ответ
Решение
Добавить метод в Dog
класс сущности как:
public void addPuppy(Puppy puppy){
if (this.puppies == null){
this.puppies = new HashSet<Puppy>();
}
puppy.setDog(this); // <--This will set dog as parent in puppy class
this.puppies.add(puppy);
}
добавлять Cascade
как ALL
за puppies
отображение в Dog
,
Когда вы хотите сохранить dog
с puppy/puppies
Вы можете написать что-то вроде:
Dog dog = ....getDog object/create new dog object
Puppy puppy = new Puppy();
// set puppy attributes.
dog.addPuppy(puppy);
//call save method for dog
dogDao.save(dog);