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

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


例如:


在构建环境中,每个表都有一个字段enabled。


删除此数据时,该字段enabled为false


And 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有更多的方法,我有更多的表。太可怕了!


你能帮助我吗?


弑天下
浏览 178回答 1
1回答

烙印99

你不能因为 Spring-data-rest 不打算那样工作。HTTP DELETE 将始终删除资源。实际上,您想要的只是更新属性值(将启用从 true 设置为 false)。事实上,你不需要实现任何你想要做的事情,因为有了 Spring-data-rest,你可以在任何资源上调用 PATCH(或 UPDATE)来更新它。当您删除数据时,只需进行 PATCH 调用而不是 DELETE 调用即可将启用的布尔值设置为 false。PATCH http://base-url/resource/id{   "enabled" : false}
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Java