相关疑难解决方法(0)

如何覆盖Spring Data CrudRepository上的delete方法?

我有一些我无法删除的对象,并且必须更新名为"已删除"的公共字段而不是它.我在那里读到我可以使用编写通用查询#{#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);
}
Run Code Online (Sandbox Code Playgroud)

但我有一个单元测试,显示我错了!

@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

}
Run Code Online (Sandbox Code Playgroud)

是不是可以覆盖那样的CrudRepository方法?

java crud jpql spring-data

8
推荐指数
1
解决办法
4833
查看次数

Hibernate Envers - 不为createQuery(...).executeUpdate()编写审计记录,只编写.persist()和.merge()

我有3种方法可以写入数据库

public void create(T object) {
    entityManager.persist(object);
}

public void update(T object) {
    object = entityManager.merge(object);
}

public int updateStatus(String id, String status) {

    final int changes =
                entityManager.createQuery("update item set state = :newState," +
                        " last_modified = current_timestamp" +
                        " where id = : id ")
                    .setParameter("newState", status)
                    .setParameter("id", id)
                    .executeUpdate();

            return changes;
}
Run Code Online (Sandbox Code Playgroud)

我遇到的问题是为了让Hibernate Envers实际将审计记录写入相应的x_aud和revinfo数据库表.它只适用于'.persist()'或'.merge()'.我不能让它为'createQuery(...). executeUpdate() '工作

我是否遗漏了某些东西,或者只是为此而努力.问题是,我的很多代码都使用.executeUpdate编写而不是合并,所以我真的需要这个来处理现有的代码.

有人可以帮忙吗?

java jboss spring hibernate hibernate-envers

4
推荐指数
2
解决办法
4105
查看次数

标签 统计

java ×2

crud ×1

hibernate ×1

hibernate-envers ×1

jboss ×1

jpql ×1

spring ×1

spring-data ×1