我有一些我无法删除的对象,必须更新名为“已删除”的公共字段而不是它。我阅读了there我可以使用#{#entityName}
编写通用查询。
出于这个原因,我试图覆盖CrudRepository#delete(…)
这样的方法:
public interface DeleteableRepository<T, ID extends Serializable> extends CrudRepository<T,ID>{
@Override
@Query("UPDATE #{#entityName} x set x.deleted = 1 where x.id = ?1")
public void delete(ID id);
}
但是我的单元测试显示我错了!
@Test
public void testDelete() {
SomeDeleteableObject sdo = new SomeDeletableObject();
sdo = getDeleteableRepository().create(sdo);
Assert.assertNotNull(sdo);
Assert.assertNotNull(sdo.getId());
Assert.assertFalse(sdo.isDeleted());
getDeleteableRepository().delete(sdo);
sdo = getDeleteableRepository().findOne(sdo.getId());
//Fails here
}
是否有可能覆盖这样的CrudRepository
方法?
答案 0 :(得分:5)
要修改查询,您需要在方法中添加@Modifying
。
确保您了解所选方法的副作用:
EntityManager
缓存。因此,后续findOne(…)
可能/仍会返回您尝试删除的对象的旧实例,以防EntityManager
已加载它。为防止这种情况,请将clearAutomatically
中的@Modifying
标记设置为true
,但请注意,这会导致所有挂起的更改被清除。@PreUpdate
事件的实体侦听器将不会收到通知。任何级联操作