mysql JOIN UPDATE 관련 질문 드립니다 !
510
4 asked
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? 예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? 예
3. 질문 잘하기 메뉴얼을 읽어보셨나요? 예
[질문 내용]
안녕하세요 영한님
Answer 1
0
안녕하세요
우선 영한님의 강의를 토대로
from절에서의 subquery는 안된다는 전제하에
쿼리를 2번 나눠서 실행하였습니다.
(참고로 mysql 기준입니다.)
혹시 다른 방법이 있다면 답변 부탁드립니다
- 기존소스
@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);
}
- 수정한 소스
@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");
List<Integer> list = queryFactory
.select(subM.id)
.from(subM)
.join(subM.team, subT)
.where(subT.name.eq("teamA"))
)).fetch();
long result = queryFactory
.update(member)
.set(member.age, member.age.add(10))
.where(member.id.in(
list
))
.execute();
assertThat(result).isEqualTo(1);
}
SpringBoot 4.X에서의 Querydsl 설정
0
86
2
querydsl 오픈소스에 대한 질문
0
71
1
예제에서의 카운트 쿼리에서 join문과 where문은 필요없지 않나요?
0
108
1
Querydsl 6.X버전에 대해서 어떻게 생각하시나요?
0
316
2
여러 테이블 조인하여 통계치를 구하고자 할 때 어떤 방법이 더 효율적일까요
1
69
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
71
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

