Spring Boot入門系列(十七)整合Mybatis,建立自定義mapper 實現多表關聯查詢!
之前講了Springboot整合Mybatis,介紹瞭如何自動生成pojo實體類、mapper類和對應的mapper.xml 檔案,並實現最基本的增刪改查功能。mybatis 外掛自動生成的mapper 實現了大部分基本、通用的方法,如:insert、update、delete、select 等大概20個左右方法,都是比較基礎的增刪改查,這些通用Mapper提供的方法基本都能滿足各種單表操作需求。但是,在實際工作中通用Mapper並不能滿足所有的工作,或是某個業務需要手寫 sql 語句、或是多表關聯時,該怎麼辦呢? 這就需要額外的一些自定義的mapper 實現一些特定的功能。下面就來介紹自定義mapper 的實現。
Spring Boot入門系列文章:https://www.cnblogs.com/zhangweizhong/category/1657780.html
一、快速實現
首先需要建立一個專案並整合mybatis等相關框架,這個之前介紹過這裡不再細說。直接在原來的基礎上實現。《Spring Boot入門系列(六)Spring Boot如何使用Mybatis XML 配置版【附詳細步驟】》
1、建立自定義 mapper
在com.weiz.mapper 包中,建立SysUserMapperCustom 介面
package com.weiz.mapper; import com.weiz.pojo.SysUser; import java.util.List; public interface SysUserMapperCustom {List<SysUser> queryUserSimplyInfoById(String userId);
}
SysUserMapperCustom 是一個介面,這裡只定義了一個方法:queryUserSimplyInfoById 。
2、建立mapper 配置檔案
建立完mapper類之後,需要建立SysuserMapperCustom 類對應的xml 配置檔案:SysuserMapperCustom.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.weiz.mapper.SysUserMapperCustom" >
<!-- 查詢使用者資訊 -->
<select id="queryUserSimplyInfoById" resultType="com.weiz.pojo.SysUser"
parameterType="java.lang.String" >
select
*
from
sys_user
where
id = #{id,jdbcType=VARCHAR}
</select>
</mapper>
說明:
id:對應的就是 介面名,
resultType:返回的是結果型別,
parameterType:引數的型別,
3、Service呼叫
首先在UserService介面中增加queryUserByIdCustom方法,然後在對應的UserServiceImpl 實現類中,注入SysUserMapperCustom 。最後實現queryUserByIdCustom 方法,在方法中呼叫前面自定義的mapper 類中方法即可。具體程式碼如下:
// 1. 在UserServiceImpl 中注入SysUserMapperCustom
@Autowired
private SysUserMapperCustom userMapperCustom; // 2. 實現介面方法,呼叫
@Override
public SysUser queryUserByIdCustom(String userId) {
List<SysUser> userList = userMapperCustom.queryUserSimplyInfoById(userId); if (userList != null && !userList.isEmpty()) {
return (SysUser)userList.get(0);
} return null;
}
二、測試
首先在原先的MybatisController 建立一個測試方法。
@RequestMapping("/queryUserByIdCustom")
public JSONResult queryUserByIdCustom(String userId) {
return JSONResult.ok(userService.queryUserByIdCustom(userId));
}
啟動專案,並在瀏覽器中輸入地址:http://localhost:8080/mybatis/queryUserByIdCustom?userId=200425AYXA733M5P
三、多表關聯查詢
上面講的是,建立一個自定義的mapper,實現自定義的查詢。多表的關聯查詢跟這個類似。
1、自定義mapper類 SysUserMapperCustom 類中,增加一個新的方法
public interface SysUserMapperCustom {
List<SysUser> queryUserSimplyInfoById(String userId);
List<SysUser> queryAllUserListCustom();
}
方法 queryAllUserListCustom() 為新加的關聯查詢的方法。
2、在之前的SysuserMapperCustom配置檔案:SysuserMapperCustom.xml 增加新方法對應的配置。
<resultMap id="UserMap" type="com.weiz.pojo.SysUser">
<id column="id" jdbcType="VARCHAR" property="id" />
<result property="username" column="username" jdbcType="VARCHAR" />
<!--封裝對映company表資料,user表與company表1對1關係,配置1對1的對映
association:用於配置1對1的對映
屬性property:company物件在user物件中的屬性名
屬性javaType:company屬性的java物件 型別
屬性column:user表中的外來鍵引用company表
-->
<association property="company" javaType="com.weiz.pojo.SysCompany" column="company_id">
<id property="id" jdbcType="VARCHAR" column="companyid"></id>
<result property="name" jdbcType="VARCHAR" column="companyname"></result>
</association>
<!--配置1對多關係對映
property:在user裡面的List<Account>的屬性名
ofType:當前account表的java型別
column:外來鍵
-->
</resultMap>
<select id="queryAllUserListCustom" resultMap="UserMap" >
SELECT
u.id,u.username,c.id companyid, c.name companyname
FROM sys_user u
LEFT JOIN sys_company c on u.company_id=c.id
</select>
上面配置的sql ,可以看到使用者表sys_user 關聯 sys_company 表,查詢完整的人員公司資訊。
說明:
1、association:用於配置1對1的對映
屬性property:company物件在user物件中的屬性名
屬性javaType:company屬性的java物件 型別
屬性column:user表中的外來鍵引用company表。
2、collection:用於配置1對多關係對映
property:在user裡面的List<Account>的屬性名
ofType:當前account表的java型別
column:外來鍵
以上就是在自定義的mapper 中實現多表關聯查詢的方法,這裡就不寫測試程式碼了,大家仔細去測試實驗。
最後
以上,就把Spring Boot 中mybatis 如何通過自定義mapper 實現多表關聯查詢介紹完了,實現起來比較簡單。上面的例子比較簡單,沒有做多表關聯,大家自己寫的時候,可以試試複雜的多表關聯。
這個系列課程的完整原始碼,也會提供給大家。大家關注我的微信公眾號(架構師精進),回覆:springboot原始碼。獲取這個系列課程的完整原始碼。