Mybatis ResultMap多表映射DTO

步驟:
1:構建DT

package com.steak.system.pojo.dto;

public class ApplyDTO {
    private Integer applyId; //申請書的ID 屬於申請表(sys_apply)
    private String selfIntroduction; //自我介紹 屬於申請表(sys_apply)
    private String applyTime; //申請時間 屬於申請表(sys_apply)
    private String userName; //申請人,屬於用戶表(sys_user)
    private String collegeName; //二級學院名稱,屬於二級學院表(sys_college)
    private String recruitName; //招聘書標題 , 屬於招聘表(sys_recruit)
    private String status; //申請狀態 屬於申請表(sys_apply
}

2:創建mybatis Mapper.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.steak.system.mapper.ApplyDOMapper">
    <resultMap id="ApplyDTO" type="com.steak.system.pojo.dto.ApplyDTO">
        <id column="apply_id" jdbcType="INTEGER" property="applyId" />
        <result column="self_introduction" jdbcType="VARCHAR" property="selfIntroduction" />
        <result column="user_name" jdbcType="VARCHAR" property="userName" />
        <result column="apply_time" jdbcType="TIMESTAMP" property="applyTime" />
        <result column="college_name" jdbcType="VARCHAR" property="collegeName" />
        <result column="status" jdbcType="INTEGER" property="status" />
        <result column="recruit_name" jdbcType="VARCHAR" property="recruitName" />
    </resultMap>

    <select id="getApplyDTO" parameterType="java.lang.String" resultMap="ApplyDTO">
        select a.apply_id,a.self_introduction,a.apply_time,u.user_name,c.college_name,a.status,r.recruit_name
        from sys_recruit r,sys_apply a,sys_user u,sys_college c
        where a.recruit_id = r.recruit_id and a.apply_people_id = u.user_id and r.apply_depatment = c.college_id
        and release_people_id = #{userId,jdbcType=VARCHAR}
    </select>
</mapper>

創建接口Mapper

List<ApplyDTO> getApplyDTO(String userId);

實體之間的轉換(少寫代碼)

如:我封裝的DTO裏面有一個字段int類型的字段status,一般在數據庫裏面我們用數字來表示,但是返回前臺我們應該用一個別人能夠理解的字段來表示(如待審覈,已審覈),由此我們需要定義一個VO(返回前端的模型,裏面的字段要和DTO裏面所要轉換的的字段相同,注意,是需要轉換的,我也可以在VO裏面定義其他的,DTO轉換的時候只轉換VO裏面和自己對應的),然後通過set方式將值轉換到VO裏面,數據字段少其實可以手動set,如果有50個字段,一個字段一個字段的去set(實際上我只需要轉換一個status字段就OK,當然也可以交給前端來處理,但是有時候前端並不知道代表什麼,所以我們儘量給前端解析好,別人就不用去猜測了),費力費時,代碼還不優雅,所以推薦使用一些實體的轉換工具,我使用的是Apache的BeanUtils,裏面有轉換的方法,如我將DTO轉換爲VO,如下便可

BeanUtils.copyProperties(VO,DTO);

這樣的話我就將所有數據轉到VO裏面了,我們在VO裏面的status字段設置爲String,然後取DTO裏面的status字段出來進行語義化成一個可理解的字段,爲什麼不取VO裏面的,要取DTO呢,前面已經說了只能轉換和自己對應的,因爲DTO裏面的status爲int類型,而VO裏面的status爲String,所以轉過來VO裏面的status爲null,所以需要取DTO裏面的status,然後賦值給VO裏面的status,如:1=待審覈 2=已審覈

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章