Spring Data JPA 更新 @Query 未更新?
在 Spring Data JPA 中,@Query 註解可讓您定義自訂 JPQL 或本機用於修改資料庫行的 SQL 查詢。然而,單獨的 @Modifying 註解可能不會觸發更新資料庫所需的刷新和持久化操作。
為了確保更改持久保存到資料庫,建議在 @Modifying 註解中使用clearAutomatically 屬性。此屬性決定執行查詢後是否自動清除持久化上下文。透過將clearAutomatically設為true,將自動偵測查詢執行期間所做的變更並將其刷新到資料庫。
以下是如何在@Modifying查詢中使用clearAutomatically的範例:
@Modifying(clearAutomatically = true) @Query("UPDATE Admin SET firstname = :firstname, lastname = :lastname, login = :login, superAdmin = :superAdmin, preferenceAdmin = :preferenceAdmin, address = :address, zipCode = :zipCode, city = :city, country = :country, email = :email, profile = :profile, postLoginUrl = :postLoginUrl WHERE id = :id") public void update(@Param("firstname") String firstname, @Param("lastname") String lastname, @Param("login") String login, @Param("superAdmin") boolean superAdmin, @Param("preferenceAdmin") boolean preferenceAdmin, @Param("address") String address, @Param("zipCode") String zipCode, @Param("city") String city, @Param("country") String country, @Param("email") String email, @Param("profile") String profile, @Param("postLoginUrl") String postLoginUrl, @Param("id") Long id);
透過將clearAutomatically設定為true,在執行更新查詢後將清除持久化上下文。這會強制對 Admin 物件所做的變更持久化到資料庫中。
請記住,clearAutomatically 僅會影響與目前 EntityManager 關聯的持久化上下文。如果您使用多個持久性上下文,您可能需要手動管理刷新,以確保變更在所有上下文之間正確同步。
以上是為什麼我的 Spring Data JPA @Query 更新沒有反映在資料庫中?的詳細內容。更多資訊請關注PHP中文網其他相關文章!