Programming-[Backend] (394) 썸네일형 리스트형 [JPA활용-1] 3. 도메인 개발 : Unique 제약 조건, main/test 환경 설정 분리, JPQL 동적 쿼리 등 스프링의 @Repository에 JPA의 @PersistenceContext 추가 그냥 스프링만 이용할 때는 @Repository 어노테이션을 추가하여 @Component 로서 Component Scan이 되게 하였다. 여기에 @PersistenceContext 어노테이션으로 EntityManager를 불러오면, 스프링이 EntityManager를 만들어서 Repository에 주입해주게 된다. Member 객체와 관련한 기본적인 기능을 갖는 MemberRepository를 보면, EntityManager를 @PersistenceContext 어노테이션과 함께 작성한 것을 확인할 수 있다. 추가로, 엔티티 자체를 들고 와야하거나 특정 파라미터를 추가해야된다면, 기본편에서 배운 JPQL 문법을 사용해야 한.. [TIL][TDD] 테스트 코드 기반으로 짜되, service 코드에서 의미적으로(기능적으로) 분리해가며 작성하기 전체 그림 1. API 분석 및 테스트 코드 작성 API 분석을 잘하는 것이 가장 중요하다. 요구되는 기능과 사양이 어떤지 명확히 알고, 그에 따른 경우의 수와 상황 등을 구체적으로 작성해본다. 최대한 많은 경우의 수를 고려하여 명기해놓고, 이것을 테스트 코드로 옮겨적으면 된다. 케이스별로 필요한 데이터를 Mock 데이터로 만들어서 테스트를 진행한다. 2. 테스트 통과를 위한 구현체 코드 작성 및 메서드 묶기 작성한 테스트 코드를 의미적, 기능별로 Service 메서드의 기능으로 묶어서 생각한다. 그리고 이 테스트 코드들을 통과하기 위한 구현체 코드를 작성한다. 테스트를 먼저 작성하고 이를 통과하기 위해 구현체 코드를 작성하므로 Test Driven Development가 된다. 이렇게 개발을 하면 최대.. [JPA활용-1] 2. 엔티티 작성 : 계층구조 연관관계 매핑 등 활용편은 대부분 아는 내용이라, 차례대로 모두 정리하지 않고 새롭게 알게된 내용들만 일부 참조하여 작성한다. 테이블명 단수형, 복수형 문제 복잡한 문제로 논란이 많지만, 테이블의 레코드 1개가 가지는 의미를 생각하여 단수로 작성한다. 테이블명이 명확한 단어로 작성되는 경우도 있지만, H1KQLW와 같은 코드로 작성되는 경우도 있다고 한다. 이런 경우에는 복수형으로 만들기가 곤란하다. 다만, order와 같은 일부 예약어는 단수로 작성 시 문제가 되므로 복수로 작성하여 혼용되기도 한다. 사용하는 DB의 종류, 프로그래밍 언어, 상황에 따라 다르겠지만 강의에서는 결국 프로젝트나 회사 단위에서 지정하기 나름이라고 한다. 일관성이 중요하다. Getter는 열되, Setter는 무조건 열지는 않는다. Entity.. [TIL] inner join, left join의 차이. 예시 및 성능, MSSQL Server Management Studio 실행 계획 차이점1. 데이터 조회량 차이 inner join과 left join의 기본적인 차이는 간단하다. 기준이 되는 from 테이블(driving table)과 조인해오는 테이블(inner table)이 있을 때, 외래키를 갖는 데이터만 불러올지, 외래키가 없더라도 모든 데이터를 driving table 기준으로 조회할지 결정하는 것이다. orders 테이블의 member_id가 members 테이블의 id값과 외래키로 연결되어 있는 상태인데, '주인없는 주문'의 경우 member_id 값이 null이기 때문에 left join에서는 아래 그림처럼 null인 값도 포함하여 5개 행이 조회되지만, inner join으로 조회한다면 외래키가 없는 레코드(행)은 빠지게 되어 4개 행만 조회된다. 따라서 비즈니스 로.. [JPA활용-1] 1. 프로젝트 생성 및 기초: .yml, @PersistenceContext, @Transactional, jar 빌드 등 활용편은 대부분 아는 내용이라, 차례대로 모두 정리하지 않고 새롭게 알게된 내용들만 일부 참조하여 작성한다. devtools 라이브러리 gradle 라이브러리에 devtools 라이브러리를 import 한다. build.gradle 파일 1 2 3 4 5 6 7 8 9 10 dependencies { implementation 'org.springframework.boot:spring-boot-starter-data-jpa' implementation 'org.springframework.boot:spring-boot-starter-thymeleaf' implementation 'org.springframework.boot:spring-boot-starter-web' implementation 'org... [JPA기본] 13. 객체지향 쿼리 언어 : JPQL-중급문법 1. 경로 표현식 경로 표현식이란 점(.)을 이용하여 객체를 탐색하는 경로를 표현하는 식을 말한다. 경로 표현식으로는 다음 세 가지 경로를 표현할 수 있다. 1 2 3 4 5 select m.username -- 상태 필드 from Member m join m.team t -- 단일 값 연관 필드 join m.orders o -- 컬렉션 값 연관 필드 where t.name = '팀A' cs 상태필드 : 탐색 종료 상태 필드는 어떤 객체의 단순 필드값을 조회하는 것이다. 상태만을 표현하므로 더 이상 경로 표현식을 통해 추가적인 탐색을 할 수 없다. 단일 값 연관 필드 : 탐색 계속, 묵시적 내부 조인 단일값 연관필드는 연관관계를 갖는 필드이므로 추가적인 탐색이 가능하다. 예를 들어 m.team.teamN.. [JPA기본] 12. 객체지향 쿼리 언어 : JPQL-기본문법 1. JPA에서 제공하는 SQL 방식 소개 JPA는 JPQL, JPA Criteria, QueryDSL, 네이티브 SQL, JDBC API 직접 사용 등의 여러 쿼리 방법을 지원한다. JPQL JPQL은 SQL을 추상화한 JPQL이라는 객체 지향 쿼리 언어를 제공한다. 다만 SQL은 DB 테이블을 대상으로 쿼리하는데, JPQL은 엔티티를 대상으로 쿼리한다는 차이가 있다. select * 이 아니라 select m from Member m 이라고 사용하는 점에서도 이를 유추할 수 있다. 그리고 SQL을 추상화했으므로 특정 데이터베이스 vendor에 의존하지 않는다는 장점이 있다. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 tx.begin(); try { Member m.. [JPA기본] 11. 값 타입 1. 값 타입 기본 엔티티 타입과 값 타입의 차이 이제껏 공부해온 엔티티 타입은 식별자(보통 id값)를 통해서 지속적으로 값을 추적할 수 있다. 어떤 엔티티의 특정 필드값이 setter 등으로 변경되면 JPA에서 식별자값을 통해 이를 감지하고 값을 변경해준다. 그러나 값 타입은 변경 시 추적이 불가하다. 그래서 유의해야될 점들이 있는데, 이 글에서는 여러 값 타입들의 종류와 사용법, 유의점에 대해서 알아본다. 사실, 추적이 안되는 값이기 때문에 결론적으로 값 타입을 잘 사용하지 않기에 JPA에서 사용하는 값 타입이라는 것이 있다는 정도만 알아도 될 것 같다. 2. 값 타입의 종류 값 타입은 다음의 3가지가 존재한다. 기본 값 타입 : int, Integer 등 자바 기본 타입이나 객체 임베디드 타입 컬렉.. 이전 1 ··· 32 33 34 35 36 37 38 ··· 50 다음