250x250
Notice
Recent Posts
Recent Comments
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 오픈소스
- Thymeleaf
- SpringBoot
- Spring Boot
- IntelliJ
- jpa
- Eclipse
- spring
- Open Source
- maven
- STS
- PostgreSQL
- Source
- oracle
- git
- AJAX
- 설정
- Python
- 문서
- ubuntu
- Docker
- MSSQL
- JavaScript
- Tomcat
- myBatis
- MySQL
- Exception
- error
- Core Java
- JDBC
Archives
- Today
- Total
헤르메스 LIFE
[Springboot] Springboot 와 Mybatis 설정에서 resultType을 Map 으로 사용 시 문제점. 본문
Spring Boot Framework
[Springboot] Springboot 와 Mybatis 설정에서 resultType을 Map 으로 사용 시 문제점.
헤르메스의날개 2024. 7. 24. 17:21728x90
개발환경
Springboot
Mybatis
JDK 11.x
<!-- src/main/resources/mapper/UserMapper.xml -->
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.group.package.mapper.UserMapper">
<select id="selectUserRequest" resultMap="Map">
SELECT id, name FROM users WHERE id = #{id}
</select>
</mapper>
이와 같은 간단한 쿼리 실행 시 Map 에 담기는 값은 Database 마다 다릅니다.
Oracle, Tibero 는 key 가 대문자로 담기게 됩니다.
List<Map<String, Object>> userList = mapper.selectUserRequest();
for(int i = 0; i < userList.size(); i++) {
HashMap userMap = (HashMap) userList.get(i);
System.out.println("ID :: " + userMap.get("ID"));
System.out.println("NAME :: " + userMap.get("NAME"));
}
MS-SQL 은 쿼리 Alias 로 key 가 생성됩니다.
List<Map<String, Object>> userList = mapper.selectUserRequest();
for(int i = 0; i < userList.size(); i++) {
HashMap userMap = (HashMap) userList.get(i);
System.out.println("ID :: " + userMap.get("id"));
System.out.println("NAME :: " + userMap.get("name"));
}
PostgreSQL 은 key 소문자로 담기게 됩니다.
List<Map<String, Object>> userList = mapper.selectUserRequest();
for(int i = 0; i < userList.size(); i++) {
HashMap userMap = (HashMap) userList.get(i);
System.out.println("ID :: " + userMap.get("id"));
System.out.println("NAME :: " + userMap.get("name"));
}
해결 방법은
1. 전부 대문자 또는 소문자로 변경하는 방법
public class ParamMap extends ListOrderedMap {
public Object put(String key, Object value) {
return upperPut(key, value);
}
public Object lowerPut(String key, Object value) {
// StringUtils.lowerCase 로 key값을 소문자로 변경
return super.put(StringUtils.lowerCase(key), value);
}
public Object upperPut(String key, Object value) {
// StringUtils.upperCase 로 key값을 대문자로 변경
return super.put(StringUtils.upperCase(ke)), value);
}
}
문제점은 추가적인 Map Class를 사용해야 한다는 겁니다.
2. org.apache.commons.collections4.map.CaseInsensitiveMap 를 사용하는 방법
<!-- src/main/resources/mapper/UserMapper.xml -->
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.group.package.mapper.UserMapper">
<select id="selectUserRequest" resultMap="org.apache.commons.collections4.map.CaseInsensitiveMap">
SELECT id, name FROM users WHERE id = #{id}
</select>
</mapper>
List<CaseInsensitiveMap<String, Object>> userList = mapper.selectUserRequest();
for(int i = 0; i < userList.size(); i++) {
CaseInsensitiveMap userMap = (CaseInsensitiveMap) userList.get(i);
System.out.println("ID :: " + userMap.get("id"));
System.out.println("NAME :: " + userMap.get("name"));
}
728x90
'Spring Boot Framework' 카테고리의 다른 글
[Spring Boot] logbak-local 설정 (0) | 2024.08.01 |
---|---|
[SpringBoot] SpringBoot + Redis Cache Sample (0) | 2024.07.31 |
[Spring Boot] Mybatis 쿼리 Interceptor 처리 테스트 (0) | 2024.05.23 |
[Spring Cloud Netflix] Eureka Gateway 샘플 (0) | 2024.03.28 |
[Spring Cloud Netflix] Eureka Client 샘플 (0) | 2024.03.14 |