您好,登錄后才能下訂單哦!
這篇文章主要介紹“Mybatis ResultMap多表映射DTO怎么實現”,在日常操作中,相信很多人在Mybatis ResultMap多表映射DTO怎么實現問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”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=已審核
到此,關于“Mybatis ResultMap多表映射DTO怎么實現”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。