inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

자바 ORM 표준 JPA 프로그래밍 - 기본편

조인

질문이 있습니다!

해결된 질문

297

sjdzn119

작성한 질문수 20

0

조인중, 세타조인과 연관관계가 없는 엔티티 조인은 같다 라고 생각해도 되나요?

예)

select m from Member m, Team t where m.name = t.name 이라는 세타 조인과,

select m from Member m join Team t on m.name = t.name 의 연관관계가 없는 엔티티 조인은 같은 건가요 ? ?

JPA java

답변 3

0

김영한

네 핵심은 두번째 방법을 사용하면 left join을 할 수 있습니다^^

감사합니다.

0

sjdzn119

이런! 간단하게 확인할 수 있는걸 확인 안하고 질문을 드렸네요 ㅠ_ㅠ

우선 Member 엔티티와 아무 연관없는 Test 라는 엔티티를 만들었고, select 쿼리 실행 전 Member 엔티티에

값을 하나 넣은 뒤 쿼리를 실행 시켰습니다.

         Member member = new Member();

member.setUsername("둘리");

member.setAge(10000);

        em.persist(member);

1. select m from Member m, Test t where m.username = t.name

>> 쿼리를 돌려보니 강의에서 말씀주신것과 동일하게 cross join 쿼리가 나갑니다.

2. select m from Member m left join Test t on m.username = t.name

>> left outer join 쿼리가 나갑니다.

차이점은 1번 cross join 은 Test 엔티티에 값이 없으면 쿼리 조회가 안되고,

2번 left outer join은 Test 엔티티에 값이 없어도, 조회가 됩니다.

혹시 더 중요한 부분을 놓치고 있다면 알려주세요

감사합니다.

0

김영한

안녕하세요. sjdzn119님

둘을 각각 실행해보시고 SQL 결과를 남겨주시겠어요^^?

그러면 둘의 차이를 바로 아실 수 있을거에요.

꼭 남겨주세요^^!

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

0

39

1

H2데이터베이스 파일 생성

0

48

2

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

0

49

2

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

0

46

1

JPQL 메소드와 락

0

48

1

Delivery @OneToOne

0

55

1

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

0

85

2

UnsupportedOperationException 발생

0

80

3

H2 Database 연결이 안됩니다.

0

87

2

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

0

78

2

h2데이터베이스 실행오류

0

103

2

persistence.xml

0

101

2

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

0

76

1

영속성 컨텍스트

0

61

1

JPA 프록시

0

87

1

Native Query와 MyBatis

0

62

1

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

0

81

1

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

0

110

3

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

0

89

3

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

0

104

2

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

0

134

1

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

0

67

1

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

0

95

1

데이터베이스가 초기화되는 것 같아요

1

173

2