我将Play Framework 1.2.4与PostgreSQL和一起使用JPA。我想拥有一个模型层次结构,并看到有一些替代方法。
PostgreSQL
JPA
我有一个基类(抽象的)和两个扩展该基类的具体类。我不想坚持这个基础课程,而我想拥有具体的课程。在基类中,我还有另一个Model类作为属性,换句话说,我@ManyToOne在基类中有关系。
@ManyToOne
我的问题是实现此目标的最佳方法是什么?使用@MappedSuperclass或@Inheritance与TABLE_PER_CLASS策略?我有点困惑,因为它们看起来 几乎 相等。
@MappedSuperclass
@Inheritance
TABLE_PER_CLASS
我还担心将来可能会遇到的查询和性能问题。
MappedSuperClass必须用于继承属性,关联和方法。
当您有一个实体和几个子实体时,必须使用实体继承。
您可以通过回答以下问题来判断您是否需要一个:模型中是否存在其他一些可以与基类相关联的实体?
如果是,则基类实际上是一个实体,您应该使用实体继承。如果没有,则基类实际上是一个包含几个不相关实体共有的属性和方法的类,您应该使用映射的超类。
例如: