inflearn logo
강의

Khóa học

Chia sẻ kiến thức

Lập trình JPA tiêu chuẩn Java ORM - Cơ bản

Ánh xạ đối tượng và bảng

엔티티에 FK컬럼값 관련 질문입니다.

2355

pwn2own

18 câu hỏi đã được viết

3

안녕하세요.

엔티티에 @ManyToOne, @OneToMany등과 같이 관계로 설정된 컬럼에 접근하는 방법에 대해 알고 싶습니다.

예를 들어 Order 엔티티가

- id(PK)

- user(관계로 설정된 값)

로 설정되어있다고 가정한다면 실제 테이블에는 user_id(FK)가 들어가게 될텐데요.

Order.getUser().getId()를 통해 user_id를 가져오게 된다면 불필요하게 user테이블에 쿼리가 한번 더 나가더라구요.

따라서 단순히 Order테이블을 조회한다음 user_id컬럼값을 가져오고 싶은데 이에 대한 방법이 궁금합니다.

인터넷을 좀 찾아보니

@Column(name = "user_id", insertable = false, updatable = false)
private Long userId;

위와 같은 형태로 설정해준다음 Order.getUserId()를 통해 가져오라고 나와있던데 맞는 방식인지 헷갈리네요.

<질문>

1. API작업을 하다보면 연관관계의 객체를 통해 접근하는게 아닌 위처럼 단순 FK컬럼의 값만 가져오고 싶을때가 있을 것 같은데 어떻게 접근하는게 옳은 방식일까요?

2. 관계를 같이 저장할 때 객체를 통한 저장이 아닌 FK키를 직접 입력해서 저장해주고 싶습니다. 위 코드를 예로 들자면 Order엔티티에 user객체를 직접 저장하는게 아닌 user_id를 입력시켜서 저장시키고 싶습니다. (user객체를 직접 저장하는 경우 무조건 user를 한번 가져와야하기 때문에) 이런 경우에는 어떻게 접근하는게 좋을까요?

감사합니다.

java JPA

Câu trả lời 2

5

yh

안녕하세요. teamhide님

1. API작업을 하다보면 연관관계의 객체를 통해 접근하는게 아닌 위처럼 단순 FK컬럼의 값만 가져오고 싶을때가 있을 것 같은데 어떻게 접근하는게 옳은 방식일까요?

-> 이 경우 쿼리가 발생하지 않습니다^^

Order.getUser().getId()를 호출하더라도 User를 SQL로 조회하지는 않습니다^^

Order -> User가 LAZY 관계이면 Order 테이블을 조회하는 시점에 userId가 이미 FK로 Order 테이블의 값에 포함되어 있기 때문이지요.

JPA는 이 값으로 User의 프록시 객체를 만들기 때문에 프록시 객체는 내부에 이미 userId를 가지고 있습니다.

따라서 이 경우 userId를 조회할 때는 프록시를 초기화 하지 않습니다.

자세한 내용은 프록시에서 설명드립니다.

2. 관계를 같이 저장할 때 객체를 통한 저장이 아닌 FK키를 직접 입력해서 저장해주고 싶습니다. 위 코드를 예로 들자면 Order엔티티에 user객체를 직접 저장하는게 아닌 user_id를 입력시켜서 저장시키고 싶습니다. (user객체를 직접 저장하는 경우 무조건 user를 한번 가져와야하기 때문에) 이런 경우에는 어떻게 접근하는게 좋을까요?

-> 이것은 좋은 방안이 아닙니다. 연관관계를 설정했으면 연관된 객체를 저장해주어야 합니다. 만약 성능이 고민이 된다면 프록시 객체로 조회해서 넣어주시면 select 쿼리를 절약할 수 있습니다. 자세한 내용은 프록시 부분을 참고해주세요.

감사합니다.

2

pwn2own

확실하게 이해했습니다. 감사합니다 :)

Entity 동등성 비교

0

4

1

실무 조언 관련 질문입니다.

0

41

1

H2데이터베이스 파일 생성

0

51

2

서브쿼리 강의에서 ALL 예시 관련 질문드립니다.

0

49

2

수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?

0

48

1

JPQL 메소드와 락

0

52

1

Delivery @OneToOne

0

57

1

17강 4~5분대 테이블 값 조회가 안됩니다.

0

89

2

UnsupportedOperationException 발생

0

82

3

H2 Database 연결이 안됩니다.

0

88

2

연관관계 매핑 질문드립니다.

0

82

2

h2데이터베이스 실행오류

0

105

2

persistence.xml

0

103

2

양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?

0

77

1

영속성 컨텍스트

0

62

1

JPA 프록시

0

90

1

Native Query와 MyBatis

0

63

1

영속성 컨텍스트는 어떤 메모리에 저장되는건가요?

0

83

1

임베디드 타입 예시 코드 관련 질문

0

112

3

명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요

0

90

3

인텔리제이 패키지 커서 단축키 질문

0

106

2

혹시 현재는 ID 데이터 타입이 String이면 안되나요?

0

136

1

양방향 연관관계 시 연관관계 주인을 설정하는 이유

0

68

1

임베디드 타입과 MappedSuperClass의 차이점이 궁금합니다.

0

95

1