inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! Querydsl

Join Update는 불가능한가요?

2441

bk11001

작성한 질문수 3

1

예를 들어 

UPDATE A_Table

SET A_Column_01 = 'disable' FROM A_Table a INNER JOIN B_Table b ON a.A_Key = b.B_Key WHERE b.B_Key is NULL

이런식으로 특정 테이블과 조인하여 업데이트 하는 구분이 Querydsl에서 가능한지요?

동적인 조건으로 저런 상황이 필요할것같은데 찾아보니 없는것같아 문의드립니다.

감사합니다.

JPA java

답변 1

1

김영한

안녕하세요. bk11001님^^

문법상 set에서 바로 조인하는 방식은 안됩니다. 대신에 다음과 같이 where 절의 서브쿼리를 이용해서 해결할 수 있습니다.

@Test
public void updateSubquery() {

Team team = new Team("teamA");
em.persist(team);

Member newMember = new Member("user1");
newMember.setTeam(team);
em.persist(newMember);

QMember subM = new QMember("subM");
QTeam subT = new QTeam("subT");

long result = queryFactory
.update(member)
.set(member.age, member.age.add(10))
.where(member.id.in(
JPAExpressions.select(subM.id)
.from(subM)
.join(subM.team, subT)
.where(subT.name.eq("teamA"))
))
.execute();

assertThat(result).isEqualTo(1);
}

참고해주세요^^

SpringBoot 4.X에서의 Querydsl 설정

0

88

2

querydsl 오픈소스에 대한 질문

0

72

1

예제에서의 카운트 쿼리에서 join문과 where문은 필요없지 않나요?

0

109

1

Querydsl 6.X버전에 대해서 어떻게 생각하시나요?

0

317

2

여러 테이블 조인하여 통계치를 구하고자 할 때 어떤 방법이 더 효율적일까요

1

70

1

fetchResults()는 더이상 권장되지 않는다는데 맞나요?

0

160

1

querydsl sum() 메서드 없어요.

0

158

2

build 디렉터리 생성

0

136

2

자바 ORM 표준 JPA 프로그래밍 - 기본편 듣고 바로 학습해도 괜찮을까요?

0

114

2

현재 Querydsl에서 from절 서브쿼리를 지원하나요?

0

90

1

오타 제보 드립니다.

0

72

2

벌크 연산과 flush, clear

0

76

1

Run As Intellij 로 변경시 Q타입 import 불가

0

87

1

QHello import하기 문제 발생

0

147

2

등록된 함수 보는법(H2Dialect) 질문

0

68

2

5.0부터 Querydsl은 향후 fetchCount() , fetchResult() 를 지원하지 않기로 결정했다고 하는데 이에 맞는 강의

1

195

2

[환경설정 PDF 부트 3.0이후 설명 질문] build.gradle에 compileQuerydsl을 정의하지 않은 상태에서 Gradle->Tasks->other->compileQuerydsl을 클릭하라고 하는 이유가 무엇인가요??

1

200

1

querydsl 설정 문제

0

222

2

quey dsl 설정부분

0

158

2

count 쿼리 관련 질문입니다!

0

75

1

stringtemplate를 이용하여 where절 검색 방법 질문 드립니다.

0

89

1

답변부탁드리겠습니다.

0

89

2

(OrderSpecifier)관련 내용 어디있을가요

0

65

1

중급문법 벌크연산에서

0

81

2