мой вопрос очень похож на Изменение типа объекта с сохранением его идентификатора , но вместо этого я использую InheritanceType.JOINED вместо Table_per_class.
Это означает, что я не могу изменять любую таблицу, просто создать новый подкласс с тем же идентификатором, что и у суперкласса.
Подводя итог, у меня есть класс Person и доктор, который расширяет Person и имеет тот же идентификатор.
Мне нужно извлечь человека из базы данных и сделать его доктором, сохранив все данные из сущности человека, но создав дополнительные данные для доктора.
При попытке слияния врач генерирует новый идентификатор, который мне не подходит.
Вот что я попробовал в первую очередь
private Person getDoctor(Person person) {
// Person already a doctor ==> OK
if (person instanceof Doctor) {
return person;
}
// Transient Person ==> //Transient Doctor OK
if (person == null) {
return new Doctor();
}
// Creates a Doctor from the person (only setting id...),
// and merges it ==>
fails as the id changes.
Doctor doctor = new Doctor(person);
return personDAO.merge(doctor);
}
sorry guys,first time here.
Here´s the code above:
private Person getDoctor(Person person) {
//Person already a doctor ==> OK
if (person instanceof Doctor) {
return person;
}
//Transient Person ==> //Transient Doctor OK
if (person == null) {
return new Doctor();
}
//Creates a Doctor from the person (only setting id...), and merges it ==> fails as the id changes.
Doctor doctor = new Doctor(person);
return personDAO.merge(doctor);
}
@Inheritance(strategy = InheritanceType.JOINED)
@Entity
public class Person{
}
@Entity
public class Doctor extends Person{
public Doctor(Person person) {
if (person != null) {
this.setId(person.getId());
}
}
}