본문 바로가기

전체 글45

JPA 정리(3) - 연관관계, 양방향 매핑 Entity의 연관 관계 DB 테이블의 연관 관계와 비슷하지만 Entity의 연관 관계와 동일하지 않다. 여러가지 연관 관계 연관 관계를 가지고 있을 때 select 외의 insert등도 한번에 처리가 가능하다. 가장 빈번하게 쓰이고 일반적인 형태, fk를 가지고 있는 Member테이블의 객체가 Team의 참조를 가지고 있다 실무에서 거의 사용되지 않는 형태지만 지원되긴 한다. 테이블에서는 무조건 다쪽에 fk가 들어간다. 로직에서 조회의 빈도성 때문에 일대다를 사용해야 한다면 차라리 다대일 양방향 매핑을 사용 이런 매핑은 공식적으로 존재하지 않는다. @JoinColumn(insertable=false, updatable=false) 사용 읽기 전용 필드를 사용해서 양방향처럼 사용하는 방법 다대일 양방향을.. 2023. 7. 17.
JPA 정리(2) - 스키마 생성 및 제약 조건 1.Entity와 테이블 매핑 @Entity 가 붙은 클래스는 JPA가 관리 → 엔티티 주의 사항 기본 생성자 필수! final 클래스 사용 금지 필드에도 final 사용 금지 setter 가능한 사용 금지 2.데이터베이스 스키마 자동 생성 DDL을 어플리케이션 실행 시점에 자동 생성 이렇게 생성된 DDL은 개발 서버에서만 사용 생성된 DDL은 운영서버에서는 사용하지 않거나, 다듬은 후 사용 데이터베이스 스키마 자동 생성에 관한 속성 create : 기존 테이블 삭제 후 다시 생성 create-drop : create와 같으나 종료시점에 테이블 drop update: : 변경분만 반영(추가만 됨) validate : 엔티티와 테이블이 정상 매핑되었는지만 확인 → 맞지 않다면 에러 발생 none : 사용하.. 2023. 7. 17.
JPA 정리(1) - 영속성 컨텍스트 영속성 컨텍스트 DB의 데이터들을 관리해주는 객체로 관리 해주는 주체 단순하게 영속성 컨텍스트 == 1차캐시라고 생각 persist(entity)를 사용하여 영속성 컨텍스트에 저장 JPA를 통해 조회한 Entity들은 자동으로 영속성 컨텍스트에 등록된다. => 이미 DB에 있는 것들을 조회 한 것이기 때문에 commit을 해도 DB에 새로 등록되지 않는다. 영속성 컨텍스트에 있는 Entity의 setter를 통해 값을 변경한 뒤 commit을 하면 DB에 동일한 ID(pk)를 가진 로우와 비교하여 달라진 부분에 대해 update를 실행,그렇기에 Entity의 setter메소드를 자제해야 한다. -> Dirty Checking !중요 : persist() 함수가 DB에 저장하는 것이 아니라 단순 영속성 컨.. 2023. 7. 17.
Spring @JsonIgnore 주의점 사이드 프로젝트로 React + SpringBoot로 프로젝트를 진행하며 DTO를 req용과 res용을 분리하지 않고 하나로 사용하고 있었다. 하지만 그로인해 @JsonIgnore를 사용했을 때 문제가 생겼다. 왜냐하면 이 어노테이션은 *직렬화와/역직렬화 모두 무시 * 하기 때문에 되도록이면 요청 데이터 매핑용 DTO와 응답 데이터 매핑용 DTO를 분리하여 사용하도록 하자! 2023. 5. 19.