안녕하세요 영한님!
218
작성한 질문수 12
안녕하세요 영한님!
Fecthjoin에 대해서 하나 여쭤보고 싶습니다!
모델 :
@Entity
@Table(name = "articles")
class Article(
@field:Id
@field:GeneratedValue(strategy = GenerationType.IDENTITY)
val id: Long?,
@field:ManyToOne(fetch = FetchType.LAZY)
@field:JoinColumn(name = "user_id")
val user: User,
) : BaseTimeEntity()
@Entity
@Table(name = "users")
class User(
@field:Id
@field:Column(length = 64, name = "user_id")
val userId: String,
@field:ManyToOne(fetch = FetchType.LAZY)
@field:JoinColumn(name = "profile_image_id")
var image: Image? = null
) : BaseTimeEntity()
@Entity
@Table(name = "images")
class Image(
@field:Id
@field:GeneratedValue(strategy = GenerationType.IDENTITY)
val id: Long? = null,
)
목적 :
article을 가져올 때 article의 user와 user의 image까지 한 번에 가져오는 것입니다!
처음엔 아래처럼 유저와 이미지를 단순 Join을 했더니 게시글을 찾아올 수 없었는데 그 이유가 무엇일지 여쭤보고 싶습니다.
override fun findByIdWithBoardUserAndUserImage(id: Long): Article? {
return queryFactory.selectFrom(article)
.where(article.id.eq(id))
.join(article.board, board).fetchJoin()
.join(article.user, user).fetchJoin()
.join(user.image,image).fetchJoin()
.fetchOne()
}
개인적으로 고민도 해봤는데
join(article.user, user).fetchJoin()
게시글과 유저를 조인할 때 innerJoin을 하게되고 이로인해
join(user.image,image).fetchJoin()
유저와 이미지를 조인할 때 조인할 유저 대상에 문제가 생기는것아닐까?라는 생각이 들었습니다.
그래서 유저와 이미지를 조인할 때 유저를 기준으로 leftJoin하여 유저를 모두 불러오면 해결할 수 있지않을까 생각하여 아래처럼 사용을 했고 게시글을 찾아올 수 있었습니다.
override fun findByIdWithBoardUserAndUserImage(id: Long): Article? {
return queryFactory.selectFrom(article)
.where(article.id.eq(id))
.join(article.board, board).fetchJoin()
.join(article.user, user).fetchJoin()
.leftJoin(user.image,image).fetchJoin()
.fetchOne()
}
그렇지만 문제의 원인과 올바른 해결방법?이 무엇일지 정확한 답을 알고 분명하게 알고가고자 질문을 남깁니다!.
답변 1
1
안녕하세요. 남기석님
fetch join도 결국에는 SQL의 join을 사용하게 됩니다.
SQL inner join, left join의 차이를 공부해보시면 답을 얻으실 수 있을거에요.
감사합니다.
join에대해 질문드립니다.
0
11
1
SpringBoot 4.X에서의 Querydsl 설정
0
158
2
querydsl 오픈소스에 대한 질문
1
101
1
예제에서의 카운트 쿼리에서 join문과 where문은 필요없지 않나요?
0
127
1
Querydsl 6.X버전에 대해서 어떻게 생각하시나요?
0
349
2
여러 테이블 조인하여 통계치를 구하고자 할 때 어떤 방법이 더 효율적일까요
1
86
1
fetchResults()는 더이상 권장되지 않는다는데 맞나요?
0
172
1
querydsl sum() 메서드 없어요.
0
169
2
build 디렉터리 생성
0
152
2
자바 ORM 표준 JPA 프로그래밍 - 기본편 듣고 바로 학습해도 괜찮을까요?
0
123
2
현재 Querydsl에서 from절 서브쿼리를 지원하나요?
0
99
1
오타 제보 드립니다.
0
79
2
벌크 연산과 flush, clear
0
85
1
Run As Intellij 로 변경시 Q타입 import 불가
0
95
1
QHello import하기 문제 발생
0
157
2
등록된 함수 보는법(H2Dialect) 질문
0
76
2
5.0부터 Querydsl은 향후 fetchCount() , fetchResult() 를 지원하지 않기로 결정했다고 하는데 이에 맞는 강의
1
209
2
[환경설정 PDF 부트 3.0이후 설명 질문] build.gradle에 compileQuerydsl을 정의하지 않은 상태에서 Gradle->Tasks->other->compileQuerydsl을 클릭하라고 하는 이유가 무엇인가요??
1
213
1
querydsl 설정 문제
0
228
2
quey dsl 설정부분
0
168
2
count 쿼리 관련 질문입니다!
0
79
1
stringtemplate를 이용하여 where절 검색 방법 질문 드립니다.
0
98
1
답변부탁드리겠습니다.
0
95
2
(OrderSpecifier)관련 내용 어디있을가요
0
68
1





