본문 바로가기

JPA18

자바 ORM 표준 JPA 프로그래밍 - 2장 JPA시작 2.2 H2 DB설치 already port in use Exception : C:/Users/[username] > h2.properties 파일에서 port 설정 변경할 수 있습니다. H2 콘솔 server 실행할 때 Database "C:/Users/klyhy/test" not found, either pre-creat : JDBC URL : jdbc:h2:~/test 로 먼저 연결한다음 (DB가 설치됨) localhost를 연결합니다. 2.5 JPA 설정 교재에선 hibernate 의존을 사용했지만 스터디 프로젝트는 hiberante core, jpa가 내장된 spring-boot-starter-data-jpa를 사용합니다. spring.datasource로 시작하는 속성을 사용합니다. DB 방언.. 2021. 7. 5.
자바 ORM 표준 JPA 프로그래밍 - 1장 JPA 소개 1장 JPA 소개 JDBC API를 직접 사용해서 코딩하면 비즈니스 로직보다 SQL, JDBC API를 작성하는데 더 오랜 시간이 걸림 → JPA를 사용하여 문제 해결 1.1 SQL을 직접 다룰 때 발생하는 문제점 관계형 데이터베이스는 가장 대중적이고 신뢰할 만한 안전한 데이터 저장소 → 자바로 개발하는 애플리케이션은 대부분 관계형 데이터베이스를 저장소로 사용 1.1.1 반복, 반복 그리고 반복 JPA를 사용하지 않고 SQL을 직접 다루게 되는 경우, 다수의 코드 작성 필요 DAO(데이터 접근 계층)을 개발하는 일은 반복의 연속 1.1.2 SQL에 의존적인 개발 데이터 접근 계층을 사용해서 SQL을 숨겨도 어쩔 수 없이 DAO를 열어서 어떤 SQL이 실행되는지 확인해야 한다는 문제점 발생 SQL에 의존하.. 2021. 7. 5.
자바 ORM 표준 JPA 프로그래밍 - 4장 엔티티 매핑 데이터베이스 스키마 자동 생성 JPA는 스키마를 자동으로 생성하는 기능을 지원한다. spring: jpa: hibernate: ddl-auto: create // create-drop, update, validate, none(default) 이 설정을 추가하면 애플리케이션 실행 시점에 데이터베이스 테이블을 자동으로 조건에 맞게 생성, 수정, 검증 등 작업을 해준다. 옵션 설명 create 기존 테이블을 삭제하고 새로 생성한다. DROP + CREATE create-drop create 속성에 추가로 애플리케이션을 종료할 때 생성한 DDL을 제거한다. DROP + CREATE + DROP update 데이터베이스 테이블과 엔티티 매핑정보를 비교해 변경사항만 수정한다. validate 데이터베이스 테이블과.. 2021. 6. 24.
Spring Data Event Handler Spring Data Event Handler Spring에서 Event를 다루는 방법이 있지만 포스팅에서는 Spring Data가 제공하는 Event를 다루는 법에 대해 사용하려 한다. Spring Data에서 제공하는 방법이 Spring framework가 제공하는 방법보다 간단하고 쉽다. 먼저 프로젝트를 만들고 build.gradle을 다음과 같이 설정해준다. plugins { id 'org.springframework.boot' version '2.5.1' id 'io.spring.dependency-management' version '1.0.11.RELEASE' id 'java' } group = 'com.event' version = '0.0.1-SNAPSHOT' sourceCompatibi.. 2021. 6. 19.
JPA - Cascade(영속성 전이) 영속성 전이 JPA에서 처리하는 Entity의 상태에 따라 종속적인 객체들의 영속성도 함께 처리되는 것이며 총 5개의 옵션이 있다. 이번 게시글에서는 PERSIST와 REMOVE에 대해 테스트해보려 한다. 테스트에 사용할 Entity들은 Team과 Member이며 OneToMany로 양방향 매핑되어있다. @Entity public class Team { @Id @GeneratedValue @Column(name = "team_id") private Long id; private String name; @OneToMany(mappedBy = "team") List members = new ArrayList(); ... } @Entity public class Member { @Id @GeneratedVal.. 2021. 6. 10.
toMany 관계에서 필터링 걸기 새로운 회사 프로젝트를 하며 JPA를 도입하며 생겼던 이슈를 해결한 방법을 소개하려 한다. 프로젝트 개발 초기 기본적인 CRUD api들을 만들며 생겼던 일인데 당시 난 아래 코드처럼 조회 api에 여러 필터를 걸며 테스트하고 있었다. Team과 Member는 OneToMany 관계이다. @Test void test2() { QTeam team = QTeam.team; QMember member = QMember.member; JPAQueryFactory query = new JPAQueryFactory(em); List result = query.selectFrom(team) .join(team.members, member) .where(member.age.eq(10)) .fetch(); result... 2021. 5. 13.