인프런 커뮤니티 질문&답변

lbrve님의 프로필 이미지
lbrve

작성한 질문수

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

회원 등록 API

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

작성

·

1.9K

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 쿼리가 날아가지 않아 성능의 이점이 보이는데 이렇게 사용해도 상관이 없을까요??

답변 1

0

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

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

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


감사합니다.

lbrve님의 프로필 이미지
lbrve

작성한 질문수

질문하기