Framework/Spring

[Mybatis] resultMap, association, collection

유로파니 2020. 9. 22. 15:53

●resultMap : 복잡한 결과매핑을 할때 사용함 (Map은 Mapping을 의미)

 - id : resultMap의 아이디

 - type : resultMap의 자료형(=resultType)

<resultMap id="baseResultMap" type="Comment">
    <id column="comment_no" jdbcType="BIGINT" property="commentNo"/>
    <result column="user_id" jdbcType="VARCHAR" property="userId" />
    <result column="reg_date" jdbcType="TIMESTAMP" property="regDate" />
    <result column="comment_content" jdbcType="VARCHAR" property="commentContent" />
</resultMap>
<select id="selectCommentByPrimaryKey" parameterType="Long" resultMap="baseResultMap">
    SELECT comment_no, user_id, comment_content, reg_date FROM tcomment
    WHERE comment_no = #{commentNo}
</select>

 

○ id : 구분자 역할을 하는 속성(기본키)

result : 일반 속성 (column(테이블) -> property(객체) 맵핑한다고 생각)

  - column : 테이블의 컬럼명

  - jdbcType : 테이블의 자료형

  - javaType : 자바의 자료형

  - property : 자바의 속성명

 

○ constructor : 생성자를 통한 맵핑, 생성자 파라미터에 명시된 순서대로 arg를 입력해야함

<resultMap id="constructorResultMap" type="Comment">
    <constructor>
        <idArg column="comment_no" javaType="long"/>
        <arg column="user_id" javaType="string"/>
        <arg column="reg_date" javaType="date"/>
        <arg column="comment_content" javaType="string"/>
    </constructor>
</resultMap>
<select id="selectCommentByPrimaryKey" parameterType="Long" resultMap="constructorResultMap">
    SELECT comment_no, user_id, comment_content, reg_date FROM tcomment
    WHERE comment_no = #{commentNo}
</select>

 - idArg : 구분자역할의 속성(기본키) / arg : 일반 속성

 

○ association : 1:1 관계의 테이블을 조인할 때 사용 (조인 객체)

  ex) 1개 Comment 에는 1명의 User만 존재

  - property : 조인객체명 / javaType : 조인객체의 자료형

private User user;

→ 자바빈파일의 자료형=javaType(User), 객체명=property(user) 일치

<resultMap id="associationResultMap" type="Comment">
    <id column="comment_no" jdbcType="BIGINT" property="commentNo"/>
    <result column="user_id" jdbcType="VARCHAR" property="userId" />
    <result column="reg_date" jdbcType="TIMESTAMP" property="regDate" />
    <result column="comment_content" jdbcType="VARCHAR" property="commentContent" />
    <association property="user" javaType="User">
        <id property="userId" column="user_id"/>
        <result property="userName" column="user_name"/>
    </association>
</resultMap>
<select id="selectCommentByPrimaryKeyAssociation" parameterType="long" resultMap="associationResultMap">
    SELECT c.comment_no, c.user_id, c.comment_content, c.reg_date, u.user_name FROM tcomment c, tuser u
    WHERE c.user_id = u.user_id AND comment_no = #{commentNo}
</select>

 

○ collection : 1:M 관계의 테이블을 조인할 때 사용 (조인 객체)

  ex) 1개의 Comment에는 M개의 Reply가 존재

 - property : 조인객체명 / ofType : collection의 자료형(지네릭)

private List<Reply> replies;

→ 자바빈파일의 컬렉션의 자료형(지네릭)=ofType(Reply), 객체명=property(replies) 일치

<resultMap id="collectionResultMap" type="Comment">
    <id column="comment_no" jdbcType="BIGINT" property="commentNo"/>
    <result column="user_id" jdbcType="VARCHAR" property="userId" /> 
    <result column="reg_date" jdbcType="TIMESTAMP" property="regDate" />
    <result column="comment_content" jdbcType="VARCHAR" property="commentContent" />
    <collection property="replies" ofType="Reply">
        <id property="replyId" column="reply_id"/>
        <result property="userId" column="user_id"/>
        <result property="replyContent" column="reply_content"/>
        <result property="regDate" column="reg_date2"/>
    </collection>
</resultMap>
<select id="selectCommentByPrimaryKeyCollection" parameterType="long" resultMap="collectionResultMap">
    SELECT c.comment_no, c.user_id, c.comment_content, c.reg_date, r.reply_content, r.reg_date AS reg_date2 FROM tcomment c, reply r
    WHERE c.comment_no = r.comment_no AND c.comment_no = #{commentNo}
</select>