中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Mybatis ResultMap多表映射DTO怎么實現

發布時間:2021-12-30 09:17:57 來源:億速云 閱讀:215 作者:iii 欄目:大數據

這篇文章主要介紹“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怎么實現”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

四会市| 皋兰县| 连州市| 伊吾县| 阿尔山市| 鄂托克前旗| 澳门| 改则县| 中阳县| 新源县| 屯昌县| 哈巴河县| 新平| 广丰县| 中西区| 广昌县| 房产| 金阳县| 彭山县| 怀远县| 黑山县| 土默特左旗| 双牌县| 德阳市| 蒙自县| 小金县| 宕昌县| 静宁县| 承德县| 南投县| 清镇市| 南昌县| 淄博市| 广丰县| 临城县| 阿城市| 漾濞| 灌阳县| 会昌县| 丰台区| 潍坊市|