안녕하세요 ! Fetch = LAZY 에 관해서 질문남깁니다.
안녕하세요~ LAZY 관련 질문이 있어서 글을 남깁니다!
LAZY 로드를 디폴트로 설정하기 위해서 propertis or yml 파일에 "spring.datasource.jpa.hibernate.enable_lazy_load_no_trans"=true 구문을 추가 하였습니다.
적용한 자바 config 파일 입니다.
properties.setProperty("hibernate.enable_lazy_load_no_trans", env.getProperty("spring.datasource.jpa.hibernate.enable_lazy_load_no_trans"));
혹시 해당 프로펄티즈 구문으로 Lazy를 디폴트로 설정해본 적이 있으신가요? 매우 간편 해보여서 프로젝트에 적용해서 쓰고 있는데 안티 패턴이여서 쓰지 말라는 글도 있더라구요. 해당 설정에 대해서 김영한 개발자님의 의견이 궁금합니다!
https://vladmihalcea.com/the-hibernate-enable_lazy_load_no_trans-anti-pattern/
Câu trả lời 3
9
안녕하세요. 김성인님 좋은 질문입니다^^ (아 이런 질문 너무 좋아요! ㅎㅎ)
트랜잭션 범위가 끝나면 영속성 컨텍스트가 함께 종료되는 것이 JPA의 기본 전략입니다.
그런데 OSIV라는 기능을 사용하면 트랜잭션 범위를 넘어서 고객의 요청이 응답될 때 까지, 그러니까 컨트롤러나 뷰에서도 영속성 컨텍스트를 유지하면서 지연로딩을 가능하게 하는 방법이 있습니다. (OSIV의 장단점은 활용2편에서 말씀드립니다.)
OSIV를 사용하면 하나의 데이터베이스 커넥션을 이미 획득한 상태로 지연로딩을 처리하기 때문에 여러번 지연로딩을 해도 하나의 데이터베이스 커넥션을 계속 이어서 사용합니다.
enable_lazy_load_no_trans 옵션은 OSIV와 비슷하기는 한데, 영속성 컨텍스트가 종료되어도, 새로운 데이터베이스 커넥션을 획득해서 지연로딩을 가능하게 해줍니다. 이 방법은 여러번 지연로딩이 있으면 그때마다 각각 새로운 데이터베이스 커넥션을 획득합니다. 따라서 성능상 매우 좋지 않습니다.
OSIV는 장단점을 잘 이해하고 매우 신중하게 사용해야 하는데, enable_lazy_load_no_trans 옵션은 성능까지 좋지 않아서, 더 권장하지 않습니다. (공식 메뉴얼에서도 권장하지 않습니다.)
그래서 해당 옵션들 없이, JPA를 잘 사용하는 방법은 활용2에서 모두 말씀드립니다^^!
감사합니다.
sdk 설정 오류
0
50
2
오탈자 - @Transactional
0
55
1
src/test/resources 테스트 경로 문제
0
50
1
상품 등록후 H2 db 출력 순서 바꿀 수 있나요?
0
64
1
MemberRepositoryTest 실행오류
0
81
1
boot 4.x >>> trasasction rolled back log & p6spy(영한님, 수업 자료 업데이트 해주시면 감사하겠습니다!!)
1
183
2
강의 마지막 QueryDSL 사용 부분 질문있습니다
1
137
2
클라이언트에서 isbn과 author 수정 요청을 한 경우에 대해 질문드립니다.
0
51
1
도메인 모델 패턴 vs 트랜잭션 스크립트 패턴
0
71
1
기본 생성자
0
60
1
h2 DB 연결시 jdbc url 변경 이유가 궁금합니다.
0
100
1
멤버서비스테스트 부분에서 막힙니다.
0
164
4
실무에서도 EntityManager를 이용해서 많이 작업하는 편일까요?
0
116
1
초반에 h2 다운로드 과정 꼭 필요한가요?
0
118
2
자신 필드에도 get으로 접근하는 이유가 있을까요?
0
113
1
24분 27초 연관관계 편의 메서드 위치
0
113
1
단건 주문만 가능하게 한건 의도한 부분이신가요?
0
108
2
빌드 툴, Gradle
0
59
1
h2연결은 된 것 같은데 엔티티 테이블까지 작성 후 확인해보아도 테이블이 안보입니다
0
76
2
Repository에서 EntityManager 주입 방식 차이
0
88
1
롬복과 사용자 정의 setter 메서드
0
71
1
주문 목록 조회 fetch join 질문드립니다
0
81
1
dirty checking 질문드립니다.
0
81
1
동시성 관련 질문입니다
0
74
1

