inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! 스프링 부트와 JPA 활용2 - API 개발과 성능 최적화

회원 등록 API

프록시 객체 getReferenceById() 에 관하여

2071

lbrve

작성한 질문수 3

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]

선생님 언제나 좋은 강의 올려주셔서 감사합니다.
JPA 강의를 전부 듣고 실무에 적용을 하려는 데

궁금한게 몇가지 있어서 문의 드립니다.

entity를 저장할 때 fk로 전달받은 값을 저장하기 위해
fk로 findById()를 날려 entity를 가져온 뒤
그 객체를 저장하려는 객체에 넣어주고 save를 했습니다.

필요한 값은 fk 하나고
이 fk 하나를 저장하기 위해 select쿼리가 날아가는게
저는 성능에 좋아보이지 않아 getReferenceById() 에 fk 를 넣고 프록시 객체를 넣어서 저장하니 정상적으로 값이 들어가는 것을 보았습니다. 쿼리도 불필요한 select 쿼리가 나가지도 않고요

실제로 이렇게 사용해도 괜찮을까요?

코드 첨부 합니다.

전달하는 dto 입니다.

public class ReservationDto {
    private Long restaurantId;
    private String reservationDate;
    private String reservationStatus;
}

 

service 코드 입니다.

Restaurant restaurant = restaurantRepository.findById(reservationDto.getRestaurantId())
        .orElseGet(() -> Restaurant.builder().restaurantId(-1L).build());

위에서 나온 entity를 가지고 값을 저장합니다.

if (restaurant.getRestaurantId() == -1L) {
    return -1L;
} else {
    Reservation savedReservation = reservationRepository.save(
            Reservation.builder()
                    .restaurantReservation(restaurant)
                    .reservationDate(reservationDto.getReservationDate())
                    .reservationStatus(reservationDto.getReservationStatus())
                    .build()
    );

reservation entity 입니다.

public class Reservation {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name="reservation_id")
    private Long reservationId;

    @ManyToOne(fetch = FetchType.LAZY)
    @JoinColumn(name = "restaurant_id")
    private Restaurant restaurantReservation;

    private String reservationDate;
    private String reservationStatus;
}

 

어차피 fk 를 클라이언트 측에서 dto 로 전달을 해주는데
findById()의 이점은 orElseGet을 통해 null 값일 경우 처리를 편리하게 해줄 수 있다는게 저는 장점으로 보입니다.
하지만 그것을 제외 한다면

Restaurant restaurant = restaurantRepository.getReferenceById(reservationDto.getRestaurantId());

이렇게 프록시 객체를 가져와 fk만 저장하는 것이 select 쿼리가 날아가지 않아 성능의 이점이 보이는데 이렇게 사용해도 상관이 없을까요??

java spring-boot JPA spring

답변 1

0

y2gcoder

안녕하세요. lbrve님, 공식 서포터즈 y2gcoder입니다.

이 링크를 참고해보시겠어요?

https://www.inflearn.com/questions/204850


감사합니다.

강의 관련 외 질문입니다.

0

81

2

SpringBoot4 + Hibernate7 모듈 등록 방법 공유

1

97

1

BeanCreationException

0

96

3

Update 후 UpdateMemberResponse 매핑할 때

0

57

1

트랜잭션을 사용 안 할 때 커넥션은 언제 가져오나요?

0

102

2

페이징 + 검색조건 관련해서 질문드립니다.

0

74

1

Query Dsl Q파일 질문입니다.

0

86

1

루트 쿼리라는것은

0

62

1

메서드를 분리하는 기준

0

71

1

findAllWithMemberDelivery 메서드 질문드립니다.

0

116

3

연관관계 매핑을 안 쓸 경우, 사용해야 하는 전략

0

92

2

fetch join과 영속화와 OSIV의 관계

0

90

2

Distinct 사용 전 결과에 대한 의문

0

118

2

레포지토리 계층에서의 트랜잭션에 대한 의문

0

63

1

영속성 컨텍스트 생명주기의 신기한 부분이 있습니다.

0

79

2

dto 필드 속 엔티티 여부

0

63

1

뷰템플릿 사용 시

0

82

2

Result 클래스 관련 질문

0

56

1

@PostConstruct 프록시 관련 질문드립니다

0

88

1

DTO 대신 Form 사용은 안되나요?

0

140

1

OSIV ON 상태일 때

0

99

1

fetch join VS fetch join 페이징 궁금증

0

189

2

양방향 연관관계 알아보는 법?

0

110

1

16강 17강 간단 정리 이게 맞을까요 ?

0

168

2