1. 程式人生 > 實用技巧 >Spring Boot入門系列(十七)整合Mybatis,建立自定義mapper 實現多表關聯查詢!

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原始碼。獲取這個系列課程的完整原始碼。