Jpa/Hibernate ManyToOne 关联非主键列 延迟加载失效

@ManyToOne配置延迟加载,如果是关联主键列,

    @ManyToOne(fetch = FetchType.LAZY)
    @JoinColumn(name = "billid", insertable = false,updatable = false, nullable = false)
    private Bill bill ;
@Setter
@Getter
@Entity
@DynamicUpdate
@Table(name = "Bill")
public class Bill implements Serializable {

    /**
     * 主键
     */

    @Id
    @Column(name = "ID")
    private String id;

   @Column(name = "SID")
    private String sid;
}

延迟加载是正常的。

但如果关联的Address的是sid而不是id的话,就延时加载就有问题。如下代码:

@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "billid", referencedColumnName = "sid", insertable = false,updatable = false, nullable = false)
private Bill bill;

这时的解决方案,需要了解PersistentAttributeInterceptable的机制。

@DynamicUpdate
@Entity
@Setter
@Getter
@Table ( name ="BillDETAIL" )
public class BillDetail implements PersistentAttributeInterceptable, Serializable {
    
@ManyToOne(fetch
= FetchType.LAZY) @JoinColumn(name = "billid", referencedColumnName = "sid", insertable = false,updatable = false, nullable = false) @LazyToOne(LazyToOneOption.NO_PROXY) private Bill bill; public Bill getBill() { if (interceptor!=null) { return (Bill)interceptor.readObject(this, "bill", bill); } return bill; } public void setBill(BillView bill) { if (interceptor!=null) { this.billView = (Bill) interceptor.writeObject(this,"owner", this.bill,bill); return ; } this.bill = bill; } @Transient private PersistentAttributeInterceptor interceptor; @Override public PersistentAttributeInterceptor $$_hibernate_getInterceptor() { return interceptor; } @Override public void $$_hibernate_setInterceptor(PersistentAttributeInterceptor interceptor) { this.interceptor = interceptor; } }

 

参考:

https://blog.csdn.net/johnf_nash/article/details/86557107     

https://blog.csdn.net/windsigirl123/article/details/60957632

转载于:https://www.cnblogs.com/hankuikui/p/11429214.html

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值