JPA

H2 DB를 사용하다보면, Embedded, Server 요런 설정을 본 적이 있을 것이다.필자 같은 경우는 MySQL을 주로 사용하다가, H2를 사용해보니 위의 개념이 너무 헷갈렸다. 그래서 해당 내용에 대해 정리해 보고자 한다.01. Server 모드이미지 출처서버 모드의 경우에는 Java 애플리케이션이 실행되는 프로세스와, H2 DB가 실행되는 포트가 완전히 구별된다.이때 두 프로세스 사이의 연결은 TCP/IP 방식으로 된다고 한다.이때 서버모드로 h2 DB를 사용하기 위해서는, 별도의 프로세스를 실행시켜야 하므로 H2 Console을 다운 및 실행시킨 상태로 Java 애플리케이션을 실행해야한다.서버 모드의 장단점은 아래와 같다.프로세스 종료 후에도 데이터가 휘발되지 않고 남아있음Java 애플리케이..
스프링부트에서 DB를 사용할 경우, 대개 Spring Daat JPA를 사용하여 DB와 상호작용한다.JPA를 사용할 경우, 프로젝트를 시작할때, 프로젝트에 정의된 Entity에 따라서 자동으로 DB를 초기화해주는 상황을 한번쯤 본 적 있을것이다. 해당 초기화를 잘 사용하면 DB 테이블을 직접 생성하지 않고도 편리하게 테이블을 사용할 수 있다.이와같은 초기화 방법에 대해 스프링 부트 공식 문서에서는 설명하고 있다.본 글에서는 해당 내용에 대해 정리해보고자 한다.DB 초기화스프링부트에서는 DB를 초기화 하기 위한 두가지 방법을 제공한다.spring.jpa.generate-ddl (boolean) : DB 초기화 기능을 끄고 킬수 있다.spring.jpa.hibernate.ddl-auto (enum) : 위의..
프로젝트를 진행하다 보면 엔티티에 생성 시간 또는 마지막 수정 시간에 대한 필드를 넣는 경우가 한번쯤 있을 것이다.이때 가장 단순한 방법으로는 setter 를 사용해서 직접 시간을 설정해 줄수도 있겠지만, 매번 직접 시간을 설정하자니 영 번거롭다.JPA에서는 이러한 상황을 위해, 시간을 자동으로 기록해주는 기능을 제공한다.한번 살펴보자.01.JPA Auditing 이란?Auditing은 '감시', '감사' (thank 말고 다른 감사..)의 의미를 가지고 있다.Auditing은 말 그대로 Entity의 생성, 변경 등을 감시하는 기능이다.JPA에서는 Auditing을 통하여 Entity가 생성되거나 변경되는 시간을 추적하고 기록한다.그럼 해당 기능을 어떻게 사용하는지 알아보자02.JPA Auditing ..
프로젝트를 진행하다 보니, Entity 클래스 내부에 존재는 해야하는데, DB에는 저장할 필요 없는 변수를 사용할 일이 생겼다.properties 파일의 값을 받아오기 위해 @Value를 사용할 변수를 정의했는데, 해당 변수를 DB에는 반영시키고 싶지 않았다.이를 위해 방법이 없나 살펴봤는데 @Transient 아노테이션을 사용하면 DB에 반영되지 않는다고 한다.ex@Entity@Getter@Setterpublic class Diary { @Transient @Value("${path.res.img.default-img}") String defaultImgPath; @Id @GeneratedValue(strategy = GenerationType.IDENTITY) priv..
DB에 데이터를 저장할 때 PK값이 꼭 존재해야한다.물론 이때 PK 값을 직접 넣어 줄 수도 있지만, 대부분의 경우에서는 DB에서 자동으로 생성되게 설정한다.Spring Data JPA에서 PK값을 자동으로 처리하기 위한 방법을 살펴보자.GeneratedValue 아노테이션 사용하기스프링부트에서 PK값을 자동 증가로 설정하기 위해서는, Entity를 정의할 때 PK 필드에 @GeneratedValue를 붙여주면 된다.이때 설정할수 있는 전략은 아래와 같은 4가지가 존재한다.GenerationType.IDENTITYGenerationType.SEQUENCEGenerationType.TABLEGenerationType.Auto하나씩 살펴보자.GenerationType.IDENTITYGenerationType..
Spring Data JPA는 Repository 인터페이스 안에 Entity 관련 메소드를 정의하여 사용한다.이때 Repository 인터페이스의 메소드 작성 규칙이 존재한다.하나씩 살펴보자식별자로 Entity 조회: findByIdT findById(Id id):엔티티 객체 반환만약 존재하지 않는 id면 null 반환Optional findById(Id id)옵셔널 객체 만환만약 존재하지 않는 id면 Option 반환Entity 삭제: deletevoid delete(T entity)엔티티 객체로 삭제void delete(Id id)아이디로 엔티티 조회 후 삭제내부적으로 findById()로 객체 탐색 후 delete() 메소드 호출만약 삭제할 엔티티가 존재하지 않으면 Exception 발생Entit..
Im_Hayden
'JPA' 태그의 글 목록