首頁  >  文章  >  Java  >  為什麼我的 Spring Data JPA @Query 更新沒有反映在資料庫中?

為什麼我的 Spring Data JPA @Query 更新沒有反映在資料庫中?

Mary-Kate Olsen
Mary-Kate Olsen原創
2024-10-25 12:34:30259瀏覽

Why is my Spring Data JPA @Query Update Not Reflecting in the Database?

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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn