@DiscriminatorColumn用法

本文详细介绍了JPA中的单表继承策略,通过@Inheritance和@DiscriminatorColumn注解实现不同实体类在单一表中的区分。示例展示了如何在父类和子类中使用这些注解,以及它们在数据库表结构中的体现。同时,还提及了其他两种继承策略: Joined策略和Table_PER_Class策略,各有其适用场景。
摘要由CSDN通过智能技术生成
1、多个entity对应同一张表,用一个字段区分
@Entity
@Cache(usage = CacheConcurrencyStrategy.READ_WRITE)
@Table(name = "GRP_UNITINFO")
@Inheritance(strategy = InheritanceType.SINGLE_TABLE)
@DiscriminatorColumn(name = "GROUPFLG", discriminatorType = DiscriminatorType.STRING)
@DiscriminatorOptions(force=true)
@DiscriminatorValue(value = "2")
public class Unitinfo extends BaseActiveEntity implements java.io.Serializable {
  

@Entity
@Table(name = "GRP_UNITINFO")
@Inheritance(strategy = InheritanceType.SINGLE_TABLE)
@DiscriminatorColumn(name = "GROUPFLG", discriminatorType = DiscriminatorType.STRING)
@DiscriminatorOptions(force=true)
@DiscriminatorValue(value = "1")
public class Subgroup extends BaseActiveEntity implements java.io.Serializable{
  

@Entity
@Cache(usage=CacheConcurrencyStrategy.READ_WRITE)
@Table(name = "GRP_UNITINFO")
@Inheritance(strategy = InheritanceType.SINGLE_TABLE)
@DiscriminatorColumn(name = "GROUPFLG", discriminatorType = DiscriminatorType.STRING)
@DiscriminatorOptions(force=true)
@DiscriminatorValue(value = "0")
@DiscriminatorOptions(force=true)可以用@ForceDiscriminator(org.hibernate.annotations.<em>ForceDiscriminator</em>)代替

@DiscriminatorColumn和@DiscriminatorOptions(force=true)在使用时,大部分情况下应该一起使用才不会出问题,但为什么Hibernate却必须在使用时要指定@DiscriminatorOptions,而且@DiscriminatorOptions中force的默认值还是false呢?
当使用Discriminator应用于单表时,才需要使用@DiscriminatorOptions(force=true),应用于JOIN_TABLE时,不需要此注解

原文详见:http://stackoverflow.com/questions/12199874/about-the-use-of-forcediscriminator-discriminatoroptionsforce-true

首先看一下最顶层的父类EmployeeEO,代码如下所示。



EmployeeEO

@Entity

@Table(name = "tb_employee")

/**继承映射策略*/

@Inheritance(strategy=InheritanceType.SINGLE_TABLE)

/**标识字段定义*/

@DiscriminatorColumn(

name="employe
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
`@ManyToAny` 注解用于将多个实体类与一个实体类相关联,从而实现多态关联。它通常用于处理复杂的继承关系。 以下是 `@ManyToAny` 注解的一些常用属性: - `metaColumn`:指定元数据列的名称,用于存储被关联实体类的类名。 - `metaValues`:指定元数据值的列表,用于映射被关联实体类的类名和实体类的主键值之间的关系。 - `targetEntity`:指定被关联实体类的类型。 以下是一个使用 `@ManyToAny` 注解的示例: ``` @Entity public class Employee { @Id private Long id; @ManyToAny(metaColumn = @Column(name = "employee_type"), metaValues = { @MetaValue(value = "Manager", targetEntity = Manager.class), @MetaValue(value = "Engineer", targetEntity = Engineer.class) }) @AnyMetaDef(idType = "long", metaType = "string", metaValues = { @MetaValue(value = "Manager", targetEntity = Manager.class), @MetaValue(value = "Engineer", targetEntity = Engineer.class) }) @JoinColumn(name = "employee_id") private EmployeeType employee; // other fields // getters and setters } @Entity @DiscriminatorValue("Manager") public class Manager extends EmployeeType { // manager specific fields and methods } @Entity @DiscriminatorValue("Engineer") public class Engineer extends EmployeeType { // engineer specific fields and methods } @Entity @Inheritance(strategy = InheritanceType.SINGLE_TABLE) @DiscriminatorColumn(name = "employee_type") public abstract class EmployeeType { @Id private Long id; // common fields and methods // getters and setters } ``` 在这个示例中,我们创建了一个实体类 `Employee`,它使用 `@ManyToAny` 注解来实现多态关联。我们使用 `metaColumn` 和 `metaValues` 属性来指定元数据列和元数据值,用于映射被关联实体类的类名和实体类的主键值之间的关系。我们还使用 `targetEntity` 属性来指定被关联实体类的类型。 在 `Employee` 实体类中,我们还使用 `@AnyMetaDef` 注解来定义元数据,指定元数据的类型和值。 在 `EmployeeType` 实体类中,我们使用 `@Inheritance` 和 `@DiscriminatorColumn` 注解来定义继承关系和鉴别器列,用于实现多态关联。 通过使用 `@ManyToAny` 注解,我们可以方便地实现多态关联,从而处理复杂的继承关系。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值