如何解决在 JPA/Hibernate 中使用另一个表中的列中的 DTYPE
我有以下实体:
@Entity
@Table(name = "devices")
public class DeviceEntity extends BaseEntity {
@ManyToOne
@JoinColumn(name = "type_id",referencedColumnName = "id")
private DeviceTypeEntity deviceTypeEntity;
@OnetoOne(fetch = FetchType.LAZY)
@JoinColumn(name = "device_attribute_id",referencedColumnName = "id")
private DeviceAttributeEntity deviceAttributeEntity;
}
@Entity
@Table(name = "device_attributes")
@discriminatorColumn(name = "DTYPE")
@Inheritance(strategy = InheritanceType.SINGLE_TABLE)
public class DeviceAttributeEntity extends BaseEntity {
@OnetoOne(mappedBy = "deviceAttributeEntity")
private DeviceEntity deviceEntity;
}
@SecondaryTable(name = "detectors",pkJoinColumns = @PrimaryKeyJoinColumn(name = "id"))
@Entity
@discriminatorValue("32")
public class HeatDetectorEntity extends DetectorEntity {
@Column(name = "temperature",table = "detectors")
private Integer temperature;
}
一切都是这样运作的。 但是现在,我想更改 DTYPE 以引用 devices.type_id(来自第一个表),而不是向 device_attributes 表添加新列(DTYPE)。 我该怎么做?
我尝试使用@discriminatorFormula(value = "SELECT d.type_id from devices as d"),但没有用。 有什么想法...?
谢谢
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。