묻고 답해요
160만명의 커뮤니티!! 함께 토론해봐요.
인프런 TOP Writers
-
미해결자바 ORM 표준 JPA 프로그래밍 - 기본편
fetch join을 했을 경우 1차 캐시에 많은 데이터가 담기면 어떻게 되나요?
안녕하세요. 강의 듣는 중 질문이 있어 남깁니다. 만약 team의 개수가 수, 수십만개의 데이터가 나오는 경우라면 모두 1차캐시로 들어가는 건가요? 만약 그럴 경우 생기는 문제는 없는건가요? 영속성 컨텍스트의 1차캐시가 감당할 수 있는 데이터의 양은 얼마나 되는건가요? 좋은 강의 감사합니다~^^
-
미해결실전! 스프링 데이터 JPA
@PersistenceContext 질문
안녕하세요 jpa api 강의와 이번 강의를 들으면서 repository에서 EntityManager를 정의하는 방식이 달라서 이 두 방식의 차이점이 궁금해서 질문드립니다. 항상 친절한 답변 감사합니다! @RequiredArgsConstructorpublic class ItemRepository { private final EntityManager em; @PersistenceContextprivate EntityManager em;
-
해결됨실전! 스프링 데이터 JPA
테스트 코드에서 @autowired 사용 질문입니다!
강의 중 테스트 코드 작성시 Repository 와 같은 경우 autowired가 아닌 생상자 주입을 권장한다고 해주셨는데 혹시 그 이유를 알 수 있을까요?? 힝상 좋은 강의 감사합니다!
-
해결됨실전! 스프링 부트와 JPA 활용2 - API 개발과 성능 최적화
어플리케이션 서비스, 도메인 서비스
안녕하세요! 강의 막바지에 어플리케이션 서비스, 도메인 서비스 이렇게 계층을 한 단계 더 나누는 경우가 있다고 말씀해주신거에 대한 질문이 있습니다. 1. 위와 같은 구조는 [컨트롤러, 어플리케이션 서비스, 도메인 서비스, 도메인, 리파지토리] 이렇게 구성되는건가요? 2. 위와 같이 구성 시 장점이 어떤 것이 있는 것인가요? 3. 위와 같은 프로젝트 구조말고 다른 구조는 어떤 것들이 있을까요? 검색어정도만 알려주실 수 있다면 구글링해서 찾아보겠습니다. 질문이 조금 많네요. 감사합니다.
-
미해결실전! 스프링 데이터 JPA
외래키에 해당하는 컬럼으로 조회하고 싶을때는 어떻게 하면 될까요???
특정 팀 소속인 사용자 목록을 얻고 싶다면 Member Repository에서 아래와 같이 만들어서 findByTeam(Team team, Pageable pageable); Team 객체에 해당하는 Team의 id 값을 담아서 조회 하고 있는데 이러한 방식 맞나요??
-
해결됨실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발
BookForm 객체를 dto 로 사용하는 것은 어떤가요?
안녕하세요 선생님 강의 정말 잘 듣고 있습니다. jpa 와 관련있는 질문은 아니지만 너무 궁금해서 올렸습니다. view 단에서 controller 단으로 데이터를 넘길 때 BookForm 객체를 넘기고 이 안의 데이터를 또다시 서비스로 넘길 때 넘길 파라미터가 많을 경우 dto를 생성하는 방법이 있다고 하셨는데 레이어 간의 구분을 명확히 하기 위한 관례 같은 건가요? 혹시 처음부터 BookForm 객체를 dto로 취급해서 넘기는 것은 좋지 않은 방법 인가요?
-
미해결자바 ORM 표준 JPA 프로그래밍 - 기본편
컬럼 기본변수지정을 래퍼로 하는것과 그냥으로 하는것은 어떤차이가있나요 ?
int vs Integer long vs Long 강의중에서는 Long으로 쓰시는거같은데 구지 그렇게 하신이유가있을까요 ?
-
미해결실전! 스프링 부트와 JPA 활용2 - API 개발과 성능 최적화
Dto 클래스 만드실 때
선생님, DTO 클래스 만드실 때 private 타입으로 만들어도 되던데.. 왜 static으로 만드시는지 궁금해서 질문 드려요~
-
미해결실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발
Item 클래스의 addStock, removeStock method 동시성 문제가 없나요?
안녕하세요. 강의 잘 보고있습니다. 여러 스레드에서 addStock 또는 removeStock method 실행시 stock 수가 변경할때 동시성 문제가 발생하지 않나요? junit으로 multi thread 요청을 테스트 해보고 싶어서 이런 저런 방법을 시도중인데 제가 테스트를 잘못한건지 동시성 문제가 발생하더라구요.. JPA에 입문한지 얼마 안되서 어떤식으로 해결하는게 좋을지 잘 모르겠습니다.. ㅠ
-
해결됨실전! 스프링 부트와 JPA 활용2 - API 개발과 성능 최적화
DTO 프로젝트 위치 관련
안녕하세요 orderSimpleQueryDTO의 경우에는 특수한 쿼리를 위한 경로에 위치시켰는데 DTO를 프로젝트에서 일반적으로 어디에 위치시키는지 궁금합니다. 강의를 들으면서 팀 프로젝트를 같이 진행하고 있는데 그 프로젝트에서는 Domain에 위치시켰습니다. 현업에서나 아니면 강사님께서는 어느 위치를 선호하시는지 궁금합니다.
-
미해결자바 ORM 표준 JPA 프로그래밍 - 기본편
em.find는 primary key만 조회할 수 있는건가요?
안녕하세요. 수업을 듣는 중 궁금사항이 있습니다. em.find는 primary key만 조회할 수 있는 기능인 건가요? primary key가 아닌 일반 데이터 값을(ex. username)을 조회하고자 할 때는 em.find로는 불가능 한건가요? 좋은 강의 감사드립니다.
-
해결됨실전! Querydsl
OneToMany 좋은 예제
먼저 좋은 강의 감사합니다. OneToMany 관계를 맺고있는 엔티티의 경우 JPA2 활용에서는 여러가지 방법으로 성능을 끌어올릴수있도록 하는 예제를 보여주셨는데 querydsl 로는 안보여주신것 같아요. 혹시 querydsl 을 사용해 OneToMany 관계의 엔티티를 모두 가져오는 좋은 방법이 있을까요.
-
해결됨자바 ORM 표준 JPA 프로그래밍 - 기본편
@GeneratedValue 질문입니다.
안녕하세요 김영한 선생님 '프록시와 연관관계 관리 - 영속성 전이(CASCADE)와 고아 객체' 강의를 수강하는 중, 해당 강좌의 7분 58초 부분에 @GeneratedValue에 의해 생성된 PK 값에 대한 질문입니다. 질문: "단일 소유자(엔티티, 부모)인 PARENT에 완전 종속이 되는 CHILD이기 때문에, child 엔티티 PK 값의 GeneratedValue 또한 parent로 부터 영향을 받는가요?" 이와 같은 질문은 다음의 과정들로 인해 가지게 되었습니다. 강좌에서 생성된 parent 엔티티의 PK는 1, 그리고 각각의 child 엔티티의 PK는 2와 3이 할당(Generated)되었습니다. 저는 'PARENT와 CHILD는 서로 다른 테이블이기 때문에, parent 엔티티의 PK 값은 1이 할당되고, 각각의 child 엔티티 PK 값은 1과 2가 할당되어야 하는 것이 아닌가?' 라는 궁금증이 생겼습니다. 이를 확인하기 위해 다음과 같이 수행해 보았으며 사진과 같은 결과를 얻었습니다. parent PK: 1, 4child PK: 2, 3, 5, 6 이러한 결과로 인해, 위의 질문과 같은 정리를 하였는데 제가 제대로 이해한 것이 맞을까요? (+) 코드 내의 주석처리한 m.t. (= my thought) 부분 또한 제가 제대로 이해한 것이 맞을까요? ====== 그리고, 좋은 강의 너무 감사드립니다.
-
미해결실전! 스프링 부트와 JPA 활용2 - API 개발과 성능 최적화
api개발고급;컬렉션조회 최적화 챕터 -> 주문조회V5 강의
안녕하세요. 실무에서는 setter 열어두면 안된다고 하셨는데, 아래 코드의 경우, setOrderItems을 어떻게 대체 해야 하나요? 감사합니다. result.forEach(o -> o.setOrderItems(orderItemMap.get(o.getOrderId())));
-
미해결실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발
Category 연관관계 편의메서드
category에 연관관계 편의 메서드 만드실 때 public void addChildCategory(Category child){ this.child.add(child); child.setParent(this);} 이렇게 만드셨는데.. public void setParent(Category parent) { this.parent = parent; parent.getChild().add(this);} 이렇게 만들어도 되는거죠? 만약 된다면 왜 첫번째 처럼 만드셨는지 궁금합니다.. 항상 잘 듣고 있습니다!
-
미해결실전! Querydsl
@QueryProjection과 fetch join
List<ProjectionResult> fetch = queryFactory .select(new QProjectionResult(classA.id, classA.relStatus.stringValue(), classA.relResult.stringValue(), classA.name, )) .from(classA) .join(classA.classB, classB).fetchJoin() .join(classB.classC, classC).fetchJoin() 안녕하세요. 위와 같이 join fecth와 queryprojection을 같이 사용하는 예제에서 실행하면 Caused by: org.hibernate.QueryException: query specified join fetching, but the owner of the fetched association was not present in the select list [FromElement{explicit,not a collection join,fetch join,fetch non-lazy properties, 와 같은 예외를 발생시킵니다. select(new QProjectionResult)가 아닌 select(classA)를 하면 정상적으로 결과가 처리되는데 어떤 차이가 있고 어떻게 해결을 해야 할까요 ? 감사합니다.
-
해결됨실전! 스프링 부트와 JPA 활용2 - API 개발과 성능 최적화
샘플 데이터를 파일로 입력하기
json 포멧의 샘플 데이터를 파일로 가지고 있을 때, 이것을 입력하기 위한 가장 좋은 방법은 어떤 것이 있을 지 궁금합니다.
-
미해결실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발
도메인분석설계 챕터 => 엔티티설계시주의점 강의 14분쯤
안녕하세요. jpa가 컬렉션을 persistentBag으로 랩핑하기 때문에, 컬력션을 필드에서 초기화한 후 바꾸지 말라고 하셨는데, 컬렉션을 바꾼다는 의미가 새로운 컬력션을 생성하거나, set이나 map 등의 다른 컬렉션으로 바꾼다는 의미인가요? 감사합니다.
-
미해결실전! Querydsl
querydsl로 where in 절 표현하기
API 개발과 성능 최적화 강의 주문 조회 V5 JPA에서 DTO 직접 조회 - 컬렉션 조회 최적화 강의 를 보면서 querydsl로 변환해 보는 공부를 하고 있습니다. 위의 코드에서 where in 절은 querydsl 로 어떻게 나타내야 하는지 궁금합니다
-
해결됨실전! 스프링 데이터 JPA
@Transactional관련 질문 입니다.
package study.querydsl.repository;import org.junit.jupiter.api.AfterEach;import org.junit.jupiter.api.BeforeEach;import org.junit.jupiter.api.Test;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.boot.test.context.SpringBootTest;import org.springframework.test.annotation.Rollback;import org.springframework.transaction.annotation.Transactional;import study.querydsl.entity.Member;import javax.persistence.EntityManager;import javax.persistence.PersistenceContext;import java.util.ArrayList;import java.util.List;@SpringBootTest@Transactional@Rollback(false)class MemberRepositoryTest { @PersistenceContext private EntityManager em; @Autowired private MemberRepository memberRepository; @Test public void test() throws InterruptedException { List<Member> members = makeList(); for (Member member : members) { test1(member.getId()); Thread.sleep(1000); } } private List<Member> makeList() throws InterruptedException { List<Member> members = new ArrayList<>(); for (int i = 0 ; i < 20 ; i++) { Member member = new Member("gon " + i, i); members.add(member); } memberRepository.saveAll(members); em.flush(); //<--- insert query는 생성되나 db 에는 아직 없음. Thread.sleep(5000); return members; } protected void test1(Long id) { Member member = memberRepository.findById(id).get(); member.setUsername("Park"); memberRepository.save(member); em.flush(); //<--- update query는 생성되나 db 에는 아직 없음. }} 안녕하세요 위와 같은 예제에서 makeList 메소드에서 생성된 리스트를 실 db에 insert를 하고 각 리스트 아이템을 처리하는 test1 메소드에서 처리된 아이템을 insert 를 하고 싶은데 em.flush를 해도 insert, update 쿼리만 발생되고 db에는 아직 결과가 들어오지 않고 test가 완전히 종료가 되는 순간 db에 값이 들어온것으로 확인 됩니다. 이를 해결하기 위해서 class에 @transactional 을 제거하고 test1 메소드에 @Transactional을 붙이니 의도한대로 makelist에서 리스트 결과가 한번 db에 저장되고 test1 메소드에서 처리된 결과도 순차적으로 db에 인서트 되는것으로 확인 했으나 연관관계가 존재하는 경우 fetch lazy 동작이 no session으로 안되던데 이를 해결하는 방법이 있는지요. 질문을 정리하면 1. Transactional 중간에 db에 값을 쓰는 방법이 있는지. 2. class에서 @Transactional을 제거 하고 test1에 @Transactional을 붙이면 연관관계 fetch lazy가 동작을 하지 않는 이유가 무엇인지 (제가 이해를 했을땐 test1 부터 영속성 컨텍스트가 관리되어 이후 메소드 호출부터는 transaction이 걸려서 fetch lazy가 동작될거라고 예상했습니다. ) 친절하고 자세한 답변 늘 감사드립니다.