작성
·
1.5K
0
답변 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
.
감사합니다.