如何根据字段值获取实体信息?
@Entity
@Table(name = "transaction")
@Getter
@Setter
@ToString(callSuper = true)
public class Transaction {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@Column(name = "src_type")
private Long sourceType;
@Column(name = "src_id")
private Long sourceId;
@OneToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "src_id", insertable = false, updatable = false)
private Company company;
@OneToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "src_id", insertable = false, updatable = false)
private User user;
}
我想在
Company
的值为 "COMPANY"时获取具有
sourceId
实体的 Tranaction
值的 sourceType
信息,并在 时获取具有
User
实体的
sourceId
值的
Tranaction
信息sourceType
的值为“USER”。
如何使用 JPA 或 Hibernate 注释来实现它?
举个例子:ID为'1'的交易记录有sourceType = 'USER'且sourceId = 1,那么我想从相关id = 1的用户表中获取
User
值,但我不想加入并从 id = 1 的公司表中获取 Company
值,因为 sourceType 的值不是“公司”。
我也尝试过使用以下注释,例如
// @SQLRestriction("sourceType = 'COMPANY'")
// @SQLJoinTableRestriction("sourceType = 'COMPANY'")
// @JoinColumnsOrFormulas({@JoinColumnOrFormula(formula = @JoinFormula(value = "sourceType = 'COMPANY'", referencedColumnName = "sourceId"))})
// @JoinFormula(value = "sourceType = 'COMPANY'", referencedColumnName = "sourceId")
但没有达到我的预期。
试试这个:
@JoinFormula(value = "(case when (src_type = 'COMPANY') then src_id else null end)")
@ManyToOne(fetch = FetchType.LAZY)
private Company company;
@JoinFormula(value = "(case when (src_type = 'USER') then src_id else null end)")
@ManyToOne(fetch = FetchType.LAZY)
private User user;
注意:在我的例子中,@OneToOne 会导致错误,我想是因为使用公式 Hibernate 无法确定关联是唯一的。