Spring/Spring Data JPA 34

[Spring Data JPA] 3-1. Defining Query Methods (1)

1. Query Lookup Strategies@EnableJpaRepositories (queryLookupStrategy)queryLookupStrategy 옵션설명CREATE_IF_NOT_FOUND (기본값)선언된 쿼리(@Query 등)이 있으면 사용하고, 없으면 메서드 이름 기반으로 쿼리 생성CREATE무조건 메서드 이름 기반으로 쿼리 생성 (어노테이션 선언 무시)USE_DECLARED_QUERY선언된 쿼리(@Query 등)만 사용, 없으면 애플리케이션 시작 시 예외 발생 2. Query CreationQuery Builder 기반 생성메서드 이름을 추론하여 JPQL Query를 생성합니다. Parsing Query Method Name요소설명예시subject쿼리 목적 (메서드 도입부)find, ..

[Spring Data JPA] 3-7. Repository query keywords

1. Supported query method subject keywordsfind…Byread…Byget…Byquery…Bysearch…Bystream…ByGeneral query method - can be used in combination with additional keywordsReturn type: the repository type- Collection, Streamable subtype, result wrapper (Page, GeoResults, store-specific)exists…ByExists projectionReturn type: booleancount…ByCount projectionReturn type: booleandelete…Byremove…ByDelete que..

[자바 ORM 표준 JPA 프로그래밍] 8. 프록시와 연관관계 관리

김영한 님의 "자바 ORM 표준 JPA 프로그래밍" 책을 정리한 포스팅 입니다. 1. 프록시엔티티를 조회할 때, 연관된 엔티티를 항상 사용하는 것은 아닙니다.모든 연관관계를 한꺼번에 가져오게 될 경우, 성능이 떨어질 수 있습니다. 프록시항목설명목적연관 엔티티를 실제 사용할 때까지 DB 조회를 지연(Lazy Loading)프록시 객체실제 클래스를 상속받아 만들어진 가짜 객체실제 객체의 참조를 보관- 프록시 객체의 메소드를 호출하면 실제 객체의 메소드를 호출 (데이터베이스 조회 지연 목적)초기화영속성 컨텍스트에 의해 초기화됨한 번만 초기화되고 재사용됨내부에 실제 객체(target) 참조식별자 활용프록시는 식별자(ID)만 저장된 상태로 생성됨식별자 접근은 초기화 없이 가능ex) 상세 정보가 필요 없는 경우 I..

[자바 ORM 표준 JPA 프로그래밍] 7. 고급 매핑

김영한 님의 "자바 ORM 표준 JPA 프로그래밍" 책을 정리한 포스팅 입니다. 1. 상속 관계 매핑데이터베이스의 슈퍼타입-서브타입 논리를 테이블로 구현 전략특징Joined StrategySingle Table StrategyTable Per Class Strategy테이블 구조부모와 자식 클래스 각각의 테이블모든 엔티티를 하나의 테이블에 저장자식 클래스마다 별도의 테이블을 생성쿼리 속도느림 (조인 필요)빠름 (조인 불필요)느림 (조인 필요)정규화✅ (테이블 정규화)❌ (모든 컬럼이 하나의 테이블에 포함)✅ (자식 테이블별로 별도 관리)테이블 크기작음큼중간컬럼 제약외래키로 관리자식 클래스마다 DTYPE 컬럼 사용모든 컬럼 nullable각 자식 테이블마다 not null 제약 가능외래키 제약✅ ❌❌ 어노..

[자바 ORM 표준 JPA 프로그래밍] 6. 다양한 연관관계 매핑

김영한 님의 "자바 ORM 표준 JPA 프로그래밍" 책을 정리한 포스팅 입니다. 1. 다대일 & 일대다구분다대일일대다다대일 + 일대다관계 방향단방향 (N → 1)단방향 (1 → N)양방향 (N → 1 + 1 → N)설명여러 개의 엔티티가 하나의 엔티티 참조하나의 엔티티가 여러 개의 엔티티 참조서로 참조 (객체 탐색 유리)외래 키 위치N쪽N쪽N쪽연관관계 주인N쪽N쪽N쪽장점구조가 단순하고 성능에 유리함구조가 단순하고 성능에 유리함객체 그래프 탐색 유리비즈니스 로직 구현 용이단점INSERT시 외래 키 직접 관리 필요INSERT시 외래 키 직접 관리 필요연관관계 주인 설정 필요객체간 참조 유지 필수사용 예단순 조회트랜잭션 설계가 명확한 경우복잡한 비즈니스 로직객체 탐색이 자주 필요한 경우복잡한 비즈니스 로직객체..

[자바 ORM 표준 JPA 프로그래밍] 5. 연관관계 매핑 기초

김영한 님의 "자바 ORM 표준 JPA 프로그래밍" 책을 정리한 포스팅 입니다. 1. 연관 관계 매핑구분설명방향성비고객체 연관 관계참조를 통해 연관관계 표현(참조에 의해 객체 그래프 탐색)단방향A → B (B는 A를 모름)객체 그래프 탐색 제한테이블 연관 관계외래키를 통해 연관관계 표현(조인을 통해 연관 테이블 조회)양방향A ↔ B (서로 참조)무한 루프 주의 어노테이션항목설명기본값@JoinColumn외래키 설정 (조인 시 사용)-- name외래키 컬럼 이름-- referencedColumnName외래키가 참조하는 컬럼명 (기본값: 참조하는 엔티티의 기본 키)-- foreignKey외래키 제약조건 (테이블 생성 시에만 적용됨)-@ManyToOne다대일 관계 설정-- optional관련 엔티티가 존재하는지..

[자바 ORM 표준 JPA 프로그래밍] 4. 엔티티 매핑

김영한 님의 "자바 ORM 표준 JPA 프로그래밍" 책을 정리한 포스팅 입니다. 1. 엔티티 매핑어노테이션설명주요 속성 및 주의사항@Entity테이블과 매핑할 엔티티 지정- 기본 생성자 필수- final class, inner class 불가- enum, interface 불가@Table엔티티와 매핑할 테이블 지정 (생략 시 클래스명)-- name: 테이블명-- schema, catalog: 스키마/카탈로그-- uniqueConstraints: 유니크 제약조건@IdPK 매핑- 필수 지정- 단독으로 사용할 경우 사용자가 직접 할당해야 함- @GeneratedValuePK 자동 할당- 대리키 사용 (DB 벤더에 위임)GenerationType-- AUTO: 현재 DB에 적합한 키 생성 전략을 자동으로 선택-..

[자바 ORM 표준 JPA 프로그래밍] 3. 영속성 관리

김영한 님의 "자바 ORM 표준 JPA 프로그래밍" 책을 정리한 포스팅 입니다. 1. 영속성 컨텍스트엔티티 객체의 영속화 작업을 관리하는 작업 영역1차 캐시, 해당 엔티티 관련 내부 쿼리 저장소 역할역할설명엔티티 상태 관리엔티티를 데이터베이스와 동기화함 (EntityManager에 의해 관리됨)트랜잭션 범위영속성 컨텍스트는 트랜잭션 단위로 엔티티를 관리- 트랜잭션이 시작되면 활성화되고, 종료 시 커밋 또는 롤백됨캐시 기능이미 로드된 엔티티는 다시 데이터베이스 조회 없이 재사용됨. 동작동작설명자동 플러시트랜잭션 커밋 전에 영속성 컨텍스트에서 변경된 데이터를 자동으로 데이터베이스에 반영.수동 플러시영속성 컨텍스트의 변경 사항을 강제로 데이터베이스에 반영. (entityManager.flush()) 예제) 자..

[자바 ORM 표준 JPA 프로그래밍] 2. JPA 시작

김영한 님의 "자바 ORM 표준 JPA 프로그래밍" 책을 정리한 포스팅 입니다. 1. 컴포넌트컴포넌트역할특징주의사항 및 사용 방식EntityManagerFactory- Connection Pool 생성 및 관리- EntityManager 인스턴스 생성- 생성 비용 높음 (Singleton으로 관리)- 앱 실행 시 한 번만 생성- 전역으로 공유EntityManager- DB 통신- 쿼리 실행 (JPQL 사용)- 커넥션 획득 (DataSource 사용)- 스레드 안전하지 않음- 요청마다 생성 또는 주입- 스레드 간 공유 금지EntityTransaction- 트랜잭션 처리 담당- EntityManager를 통해 획득- 트랜잭션 범위 안에서만 DB 작업 가능- begin() → 작업 → commit() or r..