>  기사  >  Java  >  ## Persist() 대 Merge(): 언제 어떤 JPA 메서드를 사용해야 합니까?

## Persist() 대 Merge(): 언제 어떤 JPA 메서드를 사용해야 합니까?

Linda Hamilton
Linda Hamilton원래의
2024-10-27 01:44:02793검색

##  Persist() vs. Merge(): When Should You Use Which JPA Method?

JPA와 Hibernate의 persist()와 merge()의 차이점 탐색

데이터 지속성 영역에서 JPA(Java Persistence) API)와 Hibernate는 중요한 역할을 합니다. 그 핵심에는 데이터베이스 컨텍스트에서 객체를 관리하는 두 가지 기본 방법인 persist()와 merge()가 있습니다.

persist()

persist() 메소드는 주로 데이터베이스에 새 엔터티를 생성하거나 기존 엔터티를 업데이트하는 일을 담당합니다. 해당 동작은 엔터티 상태에 따라 다릅니다.

  • 엔티티가 새 엔터티(아직 지속되지 않음)인 경우 persist()는 이를 데이터베이스에 삽입하고 식별자를 할당합니다.
  • 엔티티가 관리되는 경우(이미 지속됨) persist()는 이를 무시하거나 cascade 속성을 사용하여 구성된 경우 관련 엔터티에 작업을 계단식으로 적용합니다.
  • 엔티티가 분리된 경우(컨텍스트에서 제거됨) 예외가 발생할 수 있습니다.

이중 기능을 보여주는 persist() 사용 예:

SessionFactory sef = cfg.buildSessionFactory();
Session session = sef.openSession();
A a = new A();
session.persist(a);
a.setName("Mario");
session.flush();

이 시나리오에서 persist()는 처음에 "A"를 삽입합니다. 엔터티를 데이터베이스에 추가한 다음 지정된 이름으로 업데이트합니다.

merge()

persist()와 달리 merge()는 엔터티의 상태를 병합하는 데에만 중점을 둡니다. 분리된 엔터티를 관리되는 엔터티로 바꿉니다. 해당 동작은 다소 간단합니다.

  • 분리된 엔터티가 새 엔터티를 나타내는 경우 관리 복사본이 생성되고 해당 상태가 복사됩니다.
  • 분리된 엔터티가 기존 엔터티를 나타내는 경우 엔터티의 상태는 일치하는 관리 엔터티에 복사됩니다.
  • 분리된 엔터티가 제거된 엔터티를 나타내는 경우 예외가 발생합니다.
  • 분리된 엔터티에 cascade= 주석이 달린 관계가 있는 경우 MERGE 또는 cascade=ALL인 경우 이러한 관련 엔터티는 재귀적으로 병합됩니다.

merge()를 사용하는 예는 해당 작업을 보여줍니다.

SessionFactory sef = cfg.buildSessionFactory();
Session session = sef.openSession();
Singer singer = new Singer();
singer.setName("Luciano Pavarotti");
session.merge(singer);
session.flush();

실행 후 제공된 Singer 개체는 기존 또는 새로 생성된 관리 엔터티에 병합되어 해당 데이터베이스가 변경됩니다.

결론

Persist() 및 merge()는 JPA 및 최대 절전 모드. persist()는 삽입 및 업데이트 작업을 모두 허용하는 반면, merge()는 분리된 엔터티를 관리되는 엔터티에 병합하도록 특별히 맞춤화되었습니다. 데이터베이스 기반 애플리케이션에서 엔터티를 효과적으로 관리하려면 이들의 다양한 동작을 이해하는 것이 필수적입니다.

위 내용은 ## Persist() 대 Merge(): 언제 어떤 JPA 메서드를 사용해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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