java逻辑删除代码_java – Hibernate:如何只获取非逻辑删除的对象

博客讨论了在使用JPA时如何处理带有审计字段(如创建、更新和删除状态)的数据库表。作者遇到的问题是每个业务对象都需要过滤掉已删除的记录,并尝试使用@Where和@WhereJoinTable注解来实现,但未达到预期效果。目前,他们为每个查询手动添加了过滤条件,希望找到一种更通用的解决方案,以避免在大约150个查询中重复此操作。
摘要由CSDN通过智能技术生成

几乎我们数据库中的每个表都有一个FK到审计表,它记录了创建,更新和删除的状态(日期和用户名).

我们将审计表映射到Auditing类并使用它如下:

@MappedSuperclass

public class BusinessObject extends DataObject {

private static final long serialVersionUID = -1147811010395941150L;

@OneToOne(fetch = FetchType.EAGER,cascade = { CascadeType.ALL })

@JoinColumn(name = "AUD_ID")

private AuditingObject auditing;

...

正如您所期望的那样,几乎每个实体都从BusinessObject扩展而来.

有一种简单的方法可以说,对于每个businessObject,只接收“auditing.deleted为null”.

我已经尝试在businessObject中添加@Where和@WhereJoinTable,但这似乎不像我期望的那样工作.

目前,我已经对我的一个查询做了这个工作,但我讨厌为所有查询执行此操作,因为我们有大约150个查询.

@NamedQuery(

name="allCountries",query="SELECT c FROM Country c"

+ " LEFT JOIN FETCH c.labelDefinition "

+ " LEFT JOIN FETCH c.labelDefinition.translations "

+ " WHERE c.auditing.deleted is null"

+ " ORDER BY c.code"

)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值