전체 글 (124) 썸네일형 리스트형 1. 강의 소개 8. 프록시와 연관관계 정리 프록시 em.find() vs em.getReference() em.find() : 데이터베이스를 통해서 실제 엔티티 객체 조회 em.getReference() : 데이터베이스 조회를 미루는 가짜(프록시) 엔티티 객체 조회 프록시 객체의 초기화 Member member = em.getReference(Member.class, "id1"); member.getName(); getName() 영속성 컨텍스트에 초기화 요청 DB 조회 실제 Entity 생성 target.getName() 프록시의 특징 프록시 객체는 처음 사용할 때 한 번만 초기화 프록시 객체를 초기화 할 때, 프록시 객체가 실제 엔티티로 바뀌는 것은 아님. 초기화되면 프록시 객체를 통해서 실제 엔티티에 접근 가능 프록시 객체는 원본 엔티티를 .. 7. 고급 매핑 상속관계 매핑 관계형 데이터베이스는 상속 관계 X 슈퍼타입 서브타입 관계라는 모델링 기법이 객체 상속과 유사 상속관계 매핑 : 객체의 상속과 구조와 DB의 슈퍼타입 서브타입 관계를 매핑 슈퍼타입 서브타입 논리 모델을 실제 물리 모델로 구현하는 방법 각각 테이블로 변환 -> 조인 전략 통합 테이블로 변환 -> 단일 테이블 전략 서브타입 테이블로 변환 -> 구현 클래스마다 테이블 전략 주요 어노테이션 @Inheritance(strategy=InheritanceType.XXX) - JOINED : 조인 전략 - SINGLE_TABLE : 단일 테이블 전략 - TABLE_PER_CLASS : 구현 클래스마다 테이블 전략 @DiscriminatorColumn(name="DTYPE") @DiscriminatorVa.. 6. 다양한 연관관계 매핑 연관관계 매핑 시 고려사항 다중성 - 다대일 : @ManyToOne - 일대다 : @OneToMany - 일대일 : @OneToOne - 다대다 : @ManyToMany (실무에서 사용X) 단방향, 양방향 - 테이블 . 외래 키 하나로 양쪽 조인 가능 . 사실 방향이라는 개념이 없음 - 객체 . 참조용 필드가 있는 쪽으로만 참조 가능 . 한쪽만 참조하면 단방향 . 양쪽이 서로 참조하면 양방향 연관관계의 주인 - 테이블은 외래 키 하나로 두 테이블이 연관관계를 맺음 - 객체 양방향 관계는 A->B, B->A 처럼 참조가 2군데. 둘 중 테이블의 외래 키를 관리할 곳을 지정해야 함. - 연관관계의 주인 : 외래 키를 관리하는 참조 - 주인의 반대편 : 외래 키에 영향을 주지 않음, 단순 조회만 가능 다대일(.. 5. 연관관계 매핑 단방향 연관관계 객체를 테이블에 맞춰 데이터 중심으로 모델링하면 협력 관계를 만들 수 없다. 양방향 연관관계와 연관관계의 주인 객체의 양방향 관계 객체의 양방향 관계는 사실 양방향 관계가 아니라 다른 단방향 관계 2개다. 객체를 양방향으로 참조하려면 단방향 연관관계를 2개 만들어야 한다. 테이블의 양방향 연관관계 테이블은 외래 키 하나로 두 테이블의 연관관계를 분리 외래 키 하나로 양방향 연관관계 가짐 (양쪽으로 조인 가능) 연관관계의 주인(Owner) 양방향 매핑 규칙 객체의 두 관계 중 하나를 연관관계의 주인으로 지정 연관관계의 주인만이 외래 키를 관리(등록, 수정) 주인이 아닌 쪽은 읽기만 가능 주인은 mappedBy 속성 사용X 주인이 아니면 mappedBy 속성으로 주인 지정 외래 키가 있는 곳.. 4. 엔티티 매핑 - 기본 키 매핑 기본 키 매핑 어노테이션 @Id @GeneratedValue 기본 키 매핑 방법 직접 할당 : @Id만 사용 자동 생성 : @GeneratedValue - IDENTITY : 데이터베이스에 위임. MYSQL - SEQUENCE : 데이터베이스 시퀀스 오브젝트 사용. ORACLE . @SequenceGenerator 필요 - TABLE : 키 생성용 테이블 사용. 모든 DB에서 사용 . @TableGenerator 필요 - AUTO : 방언에 따라 자동 지정. 기본값 IDENTITY 전략 기본 키 생성을 데이터베이스에 위임 주로 MySQL, PostgreSQL, SQL Server, DB2 에서 사용 (ex. MySQL의 AUTO_INCREMENT) JPA는 보통 트랜잭션 커밋 시점에 INSERT SQL .. 4. 엔티티 매핑 - 필드와 컬럼 매핑 필드와 컬럼 매핑 매핑 어노테이션 @Column : 컬럼 매핑 @Temporal : 날짜 타입 매핑 @Enumerated : enum 타입 매핑 @Lob : BLOB, CLOB 매핑 @Transient : 특정 필드를 컬럼에 매핑하지 않음(매핑 무시) @Column name : 필드와 매핑할 테이블의 컬럼이름(default : 객체의 필드 이름) insertable, updatable : 등록, 변경 가능 여부(default : TRUE) nullable(DDL) : null 값의 허용 여부를 설정한다. false로 설정하면 DDL 생성 시에 not null 제약조건이 붙는다. unique(DDL) : @Table의 uniqueConstraints와 같지만 한 컬럼에 간단히 유니크 제약조건을 걸 때 사용.. 4. 엔티티 매핑 - 객체와 테이블 매핑 엔티티 매핑 객체와 테이블 매핑 : @Entity, @Table 필드와 컬럼 매핑 : @Column 기본 키 매핑 : @Id 연관관계 매핑 : @ManyToOne, @JoinColumn 객체와 테이블 매핑 @Entity @Entity가 붙은 클래스는 JPA가 관리하며 엔티티라 한다. JPA를 사용해서 테이블과 매핑할 클래스는 @Entity 필수 주의 - 기본 생성자 필수 (파라미터가 없는 public 또는 protected 생성자) - final 클래스, enum, interface, inner 클래스 사용 X - 저장할 필드에 final 사용 X @Table @Table은 엔티티와 매핑할 테이블 지정 name : 매핑할 테이블 이름 (기본값 : 엔티티 이름을 사용) catalog : 데이터베이스 cat.. 이전 1 ··· 4 5 6 7 8 9 10 ··· 16 다음