0

标题有点奇怪,让我澄清一下。

我有两个对象,车库和车辆,是一对多的关系。有多种类型的车辆,例如轿车和卡车;该类型作为字符串保存在 Vehicle 表中。

这是两个类:

@Entity
@Table(...)
public class Garage {
    ....

    @Column(name = "garageId")
    private Integer garageId;

    @OneToMany
    @JoinColumn(name = "garageId")
    private Set<Vehicle> vehicles;

    ....
}

@Entity
@Table(...)
public class Vehicle {
    ....

    @Column(name = "garageId")
    private Integer garageId;

    //could be "Truck" or "Car"
    @Column(name = "type")
    private String type;

    ....
}

为了区分车辆的类型,目前我们必须查看类型列并使用枚举。我想做的是拥有 Vehicle 的子类,例如 Car 和 Truck,来表示不同的类型,而不是依赖于 Type 字段。然后我的代码instanceof可以确定类型而不是使用该字段。

但是,我不知道如何告诉 Hibernate 如何根据 Type 列的值来实例化子类,或者它是否可以。

我会很感激你们能提供的任何帮助。提前致谢!

4

1 回答 1

1

如果要保存当前的数据库模式,则需要使用以列为判别器的SINGLE_TABLE继承策略:type

@Entity 
@Table(...) 
@Inheritance(strategy = InheritanceType.SINGLE_TABLE)
@DiscriminatorColumn(name = "type")
public abstract class Vehicle { ... }

@Entity
@DiscriminatorValue("...")
public class Car extends Vehicle { ... }

@Entity
@DiscriminatorValue("...")
public class Truck extends Vehicle { ... }
于 2010-11-10T21:46:18.947 回答