如何修改spring data jpa默认查询和删除方法?例如:在构建环境中,每个表都有一个字段enabled。删除此数据时,该字段enabled为falseAnd when select the data, only select enabledis true.所以,spring data jpa 默认方法不能做到这一点。如何修改这个?我找到方法 /** * 自己写的删除方法 * * @param aLong 删除的id */ @Modifying @Query("UPDATE Book SET enabled = false WHERE id = :id") @RestResource(exported = false) void delete(@Param("id") Long aLong); /** * 重写删除方法 * * @param entity 删除的实体 */ @Override default void delete(Book entity){ delete(entity.getId()); }但是JpaRepository有更多的方法,我有更多的表。太可怕了!你能帮助我吗?
1 回答
烙印99
TA贡献1829条经验 获得超13个赞
你不能因为 Spring-data-rest 不打算那样工作。HTTP DELETE 将始终删除资源。实际上,您想要的只是更新属性值(将启用从 true 设置为 false)。事实上,你不需要实现任何你想要做的事情,因为有了 Spring-data-rest,你可以在任何资源上调用 PATCH(或 UPDATE)来更新它。当您删除数据时,只需进行 PATCH 调用而不是 DELETE 调用即可将启用的布尔值设置为 false。
PATCH http://base-url/resource/id
{
"enabled" : false
}
添加回答
举报
0/150
提交
取消