考虑下面的课程
产品(抽象根类)
@Entity
@Table(name="PRODUCT")
@Inheritance(strategy=InheritanceType.JOINED)
@DiscriminatorColumn(name="PRODUCT_TYPE")
public abstract class Product {
@Id
@GeneratedValue
@Column(name = "product_ent_id", insertable = false)
private int productEntId;
}
汽车(扩展产品的另一个父类)
@Entity
@Table(name="CAR")
@DiscriminatorValue(value="Car")
@PrimaryKeyJoinColumn(name="car_ent_id")
@Inheritance(strategy=InheritanceType.JOINED)
@DiscriminatorColumn(name="CAR_TYPE")
public abstract class Car extends Product {
@Column(name = "car_ent_id", insertable = false, updatable = false)
private int carEntId;
}
Speeder (延伸汽车的最后一个孩子)
@Entity
@Table(name="SPEEDER")
@DiscriminatorValue(value="Speeder")
@PrimaryKeyJoinColumn(name="speeder_ent_id")
public class Speeder extends Car {
@Column(name = "speeder_ent_id", insertable = false, updatable = false)
private int speederEntId;
}
当JPA使用鉴别器将我的对象模型映射到我的数据模型时,在单个父对子层次结构中使用鉴别器对我来说没问题,鉴别器值已正确设置,但是当我添加了另一层次的层次结构< strong> Speeder-extends-Car-extends-Product ,鉴别器值或无法正常工作,
如果我只在单个继承中使用带有鉴别器的连接继承(例如,子对父),则鉴别器值在其受尊重的列中正确映射,但现在我添加了另一个层次结构,Speeder的鉴别器值是放在产品表的鉴别器列中的值,而 Car表的鉴别器列保留为null值,我希望你能理解我在这里想要实现的目标,这可能吗?任何工作?周围有很多例子,但是我找不到一个能够说明更深层次结构的例子,例如这个joined inheritance tables,但是层次结构更深,周围的例子只有简单的层次结构,而其他人使用这个例子几乎相同一种策略。任何帮助或启发将不胜感激。