반응형
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- spring
- 스프링 부트
- DI
- thymeleaf
- SQL
- 스프링
- Javascript
- kafka
- assertThrows
- db
- 스프링 빈
- java
- 스프링부트
- mybatis
- 필드 주입
- Effective Java
- 스프링 부트 기본
- resultMap
- sqld
- @Configuration
- 생성자 주입
- 싱글톤
- DIP
- JPA
- assertThat
- 스프링 컨테이너
- jdbc
- springboot
- 스프링 부트 입문
- 스프링 프레임워크
Archives
- Today
- Total
선 조치 후 분석
[MyBatis] resultMap? resultClass? 차이는? 본문
728x90
반응형
SMALL
자바로 개발을 하면서 SQL을 작성하는 XML에서 resultMap, resultClass를 흔하게 볼 수 있었다.
오늘은 2개의 차이점과 개념에 대해서 알아보려고 정리해보았다.
참고 (resultClass -> resultType으로 변경)
iBatis | MyBatis |
resultClass | resultType |
resultType :
- 이 구문에 의해 리턴되는 기대 타입의 패키지 경로를 포함한 클래스명 전체 or 별명(Alias)을 입력
- 매핑하려는 자바 클래스의 전체 경로를 입력
- VO, DTO 등의 객체를 담을 수 있는 클래스의 경로를 명시
- 자동 매핑이 되지만 일부 제한 있음
<select id="selectInfo" resultType="com.ex.test.SelectVo">
~
</select>
<select id="selectCount" resultType="int">
~
</select>
resultMap :
- 개발자가 직접 POJO 클래스에 매핑
- 번거롭지만 제한 없이 사용 가능
<resultMap id="selectMap" resultType="com.ex.test.SelectVo">
<result property="selectId" column="USER_ID"/>
<result property="selectName" column="USER_NAME"/>
</resultMap>
<select id="selectInfo" resultMap="selectMap">
~
</select>
추가적으로 Ibatis에서 사용되는 방법도 알아보았다.
parameterClass :
- 이 구문 실행에 필요한 값을 포함하고 있는 클래스의 타입을 설정
- 기본자료형, ValueObject, Map 타입을 설정할 수 있음
- 조건이 있는 DELETE 구문이라면 작성해야 한다
resultClass :
- 이 구문 실행 후 조회된 값을 담는 클래스의 타입을 설정
- SELECT 쿼리일때만 사용 가능
- 기본자료형, ValueObject, Map 타입을 설정할 수 있음
- Delete문과 같이 return 받을 게 없다면 resultClass는 사용할 필요 없음
<insert id="insertInfo" parameterClass="com.ex.test.SelectVO" >
~
</insert>
<update id="updateInfo" parameterClass="com.ex.test.SelectVO">
~
</update>
<delete id="deleteInfo" parameterClass="int"> --조건이 있는 삭제
~
</delete>
<select id="selectInfo" resultClass="int">
~
</select>
<select id="selectInfo" parameterClass="string" resultClass="int"> --조건이 있는 조회
~
</select>
728x90
반응형
LIST
'Solution > DB' 카테고리의 다른 글
[SQL] WHERE 절 <if> 와 <isNotEmpty> 차이 (0) | 2022.02.14 |
---|---|
DECODE 함수 사용법 (0) | 2021.12.28 |
[Oracle] 테이블 생성법 (CRATE, PK, COMMENT) + MySQL과의 차이점 (0) | 2021.11.09 |
[SQL] SELECT .* VS SELECT 컬럼명 조회문 차이? (0) | 2021.11.08 |
[DB] 프로시저(Procedure) VS 사용자 정의 함수(Function) 차이 (0) | 2021.10.20 |