jdbcTemplate 동적쿼리 질문입니다.
1779
작성한 질문수 3
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.
답변 2
3
감사합니다. 댓글 참조하여 다음과 같이 작성해보았습니다.
public Optional<Member> findByIdOrName(Long id, String name) {
StringBuilder query = new StringBuilder("select * from member where 1=1");
List<String> queryArgs = new ArrayList<>();
if(id != null) {
query.append(" and id=?");
queryArgs.add(String.valueOf(id));
}
if(name != null) {
query.append(" and name=?");
queryArgs.add(name);
}
List<Member> result = jdbcTemplate.query(query.toString(), memberRowMapper()
, queryArgs.toArray());
return result.stream().findAny();
}
0
안녕하세요. aq14 님, 공식 서포터즈 codesweaver 입니다.
.
해당 조건들을 만족하기 위해선 '동적 쿼리'라고 하는 키워드로 검색하시면 많은 도움을 얻으실 수 있습니다. 가장 고전적인 방법은 파라미터의 존재 여부를 체크하여 존재시 String 을 계속 이어 붙이는 방법입니다. 아래의 링크를 참조하시면 String을 이어붙이며 해결하는 코드를 살펴보실 수 있습니다.
db2 - JbdcTemplate - PreparedStatements with Dynamic SQL Query - Stack Overflow
.
감사합니다.
..
0
76
2
Unused property.....
0
99
2
project JDK is misconfigured
0
132
2
외부 API의 ID 타입(String/UUID)과 내부 도메인의 ID 타입(Long)이 불일치할 때의 설계 정석
0
82
2
단위/통합 테스트 버전충돌 문제
0
91
2
❗️springboot 4.0.2 버전 aspectj dependency 설정❗️
0
229
1
왜 컨트롤러는 변한게 없는데 새로 만든 html 파일이 뜨나요?
0
102
2
윈도우 build test오류 질문
1
102
2
테스트 관련 공부에 대한 조언을 얻고 싶습니다
0
99
2
테스트 실행 시 에러 질문
0
291
1
name을 통한 비교와 객체를 통한 비교
0
77
1
빌드 후 libs 없음
1
129
1
윈도우 gradlew.bat 에러
0
167
1
@PostMapping("/members/new")가 동작하지 않습니다
0
88
1
java static class와 kotlin class
0
78
1
스프링 DB연결
0
126
1
소요 시간
0
85
2
ddl.sql에 빨간 밑줄
1
101
2
welcome page 에러
0
181
3
잘 모르겠습니다.
0
164
2
fail을 똑같이 쳤는데 오류가 발생해요
0
156
2
index.html Welcome page
0
121
1
프로젝트 gradle-groovy ?
0
369
1
테스트코드 메서드명 한글
0
201
2





