Spring Data JPA 업데이트 @Query Not Updating: The Flush Dilemma
Spring Data JPA에서 업데이트 작업에 @Query 주석을 사용할 때, EntityManager의 동작을 이해하는 데 중요합니다. 기본적으로 EntityManager는 데이터베이스에 대한 변경 사항을 자동으로 플러시하지 않습니다. 이로 인해 업데이트가 무시되는 것처럼 보이는 예기치 않은 결과가 발생할 수 있습니다.
제공된 코드의 경우 업데이트 쿼리 후 관리 엔터티에 대한 변경 사항이 데이터베이스에 플러시되지 않았기 때문에 통합 테스트가 실패했습니다. . 이 문제를 해결하려면 @Modifying 주석과 함께clearAutomatically = true 옵션을 사용하는 것이 좋습니다.
@Modifying(clearAutomatically = true) @Transactional @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, ...);
이 옵션을 추가하면 EntityManager는 업데이트 쿼리가 실행된 후 변경 사항을 자동으로 플러시하여 다음을 보장합니다. 이는 데이터베이스에 유지됩니다.
추가 관찰:
위 내용은 내 Spring 데이터 JPA @Query 업데이트가 작동하지 않는 이유: EntityManager 플러시 미스터리?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!