如何通过JPA或Hibernate注释有条件地连接实体的字段值?

问题描述 投票:0回答:1

如何根据字段值获取实体信息?

@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")

但没有达到我的预期。

hibernate jpa hibernate-mapping
1个回答
0
投票

试试这个:

@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 无法确定关联是唯一的。

© www.soinside.com 2019 - 2024. All rights reserved.