>Java >java지도 시간 >내 Spring 데이터 JPA @Query 업데이트가 작동하지 않는 이유: EntityManager 플러시 미스터리?

내 Spring 데이터 JPA @Query 업데이트가 작동하지 않는 이유: EntityManager 플러시 미스터리?

Linda Hamilton
Linda Hamilton원래의
2024-10-27 07:10:29284검색

Why Does My Spring Data JPA @Query Update Not Work: The EntityManager Flush Mystery?

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는 업데이트 쿼리가 실행된 후 변경 사항을 자동으로 플러시하여 다음을 보장합니다. 이는 데이터베이스에 유지됩니다.

추가 관찰:

  • findByEmail 및 findByLogin 파인더에 대한 SQL 문에 표시된 제한 2 절은 데이터베이스입니다. WHERE IN 쿼리와 함께 제한 절을 사용할 때의 특정 동작입니다. Spring Data는 이 동작을 사용하여 파생된 정보를 기반으로 쿼리를 최적화합니다.
  • MySQL과 Java의 동작 차이는 다른 JDBC 드라이버 사용이나 연결 설정과 관련이 있을 수 있습니다. 두 환경 모두에서 사용되는 드라이버와 연결 설정 간의 일관성을 보장하는 것이 중요합니다.

위 내용은 내 Spring 데이터 JPA @Query 업데이트가 작동하지 않는 이유: EntityManager 플러시 미스터리?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.