栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

使用注释在Hibernate中映射多级继承

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

使用注释在Hibernate中映射多级继承

您具体遇到什么问题?通过联接的子类映射类层次结构非常简单:

@Entity@Inheritance(strategy=InheritanceType.JOINED)public class A implements Serializable { ... }@Entitypublic class B extends A { ... }@Entity@PrimaryKeyJoinColumn(name="A_ID")public class C extends A { ... }@Entity@PrimaryKeyJoinColumn(name="B_ID")public class D extends B { ... }

更新 (基于Michal的评论)。

如果您确实要使用区分符(并且您应该有 充分的
理由这样做),则可以通过将基于类的表策略与辅助表进行混合来实现:

@Entity@Table(name="A_table")@Inheritance(strategy=InheritanceType.SINGLE_TABLE)@DiscriminatorColumn(name="entity_type")@DiscriminatorValue("A")public class A implements Serializable { ... }@Entity@SecondaryTable(name="B_table")public class B extends A { ... }@Entity@SecondaryTable(name="C_table", pkJoinColumns={    @PrimaryKeyJoinColumn(name="A_ID", referencedColumnName="ID")))public class C extends A { ... }@Entity@SecondaryTable(name="D_table", pkJoinColumns={    @PrimaryKeyJoinColumn(name="B_ID", referencedColumnName="ID")))public class D extends B { ... }

这种方法的缺点是,您必须为每个映射的属性显式指定表:

public class D extends B {  @Column(table="D_table")  private String someProperty;  ...}


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/401306.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号