Код: Выделить всё
@Entity(name = "request")
public class VisitRequest {
@Id
@GeneratedValue
private Long id;
@OneToMany(mappedBy = "visitRequest", cascade = CascadeType.ALL, orphanRemoval = true)
@JsonManagedReference
private List visitors;
//default constructor, getters and setters
}
@Entity
@Inheritance(strategy = InheritanceType.JOINED)
@JsonTypeInfo(use = JsonTypeInfo.Id.CLASS, include = JsonTypeInfo.As.PROPERTY, property = "class")
public class Visitor {
@Id
@GeneratedValue
private Long id;
@ManyToOne
@JsonBackReference
private VisitRequest visitRequest;
//default constructor, getters and setters
}
@Entity
public class ContactPerson extends Visitor {
private PhoneNumber phoneNumber;
//default constructor, getters and setters
}
Servlet.service() для сервлета [dispatcherServlet] в контексте с выброшенным путем
[] исключение [Ошибка обработки запроса; вложенное исключение:
org.springframework.orm.ObjectRetrievalFailureException: Object
[id=null] не принадлежит к указанному подклассу
[cern.ais.visits.core.domain.visitor.Visitor] : класс данного объекта
не соответствует классу постоянной копии; вложенное исключение:
org.hibernate.WrongClassException: объект [id=null] не принадлежал к
указанному подклассу [cern.ais.visits.core.domain.visitor.Visitor] :
класс данного объекта не соответствует классу постоянной копии] с
первопричиной
Возможно, проблема в том, что в базе данных в таблицах contact_person и visitor используется один и тот же идентификатор?
Как решить проблему? Я искал решения, но ни одно из них мне не помогло.
Подробнее здесь: https://stackoverflow.com/questions/438 ... d-subclass
Мобильная версия