为了账号安全,请及时绑定邮箱和手机立即绑定

如何修改spring data jpa默认查询和删除?

如何修改spring data jpa默认查询和删除?

弑天下 2022-05-25 17:27:12
如何修改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

}


查看完整回答
反对 回复 2022-05-25
  • 1 回答
  • 0 关注
  • 177 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信