SpringBoot整合Mybatis-Plus實(shí)現(xiàn)關(guān)聯(lián)查詢(xún)
一、搭建環(huán)境
1.創(chuàng)建Maven普通項(xiàng)目
2.添加依賴(lài)坐標(biāo)
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.2.RELEASE</version>
</parent>
<dependencies>
<!--單元測(cè)試-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
</dependency>
<!-- 數(shù)據(jù)庫(kù)驅(qū)動(dòng) -->
<!--mysql驅(qū)動(dòng)-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<!-- <version>8.0.19</version>-->
</dependency>
<!-- lombok 簡(jiǎn)化set get toString -->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
<!-- mybatis-plus -->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.4.3.1</version>
</dependency>
</dependencies>3.導(dǎo)入SpringBoot的相關(guān)插件
<plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin>
4.創(chuàng)建mapper包、pojo包和啟動(dòng)類(lèi)Starter
mapper包:
在該包下定接口繼承BaseMapper接口
pojo包:
在該包下定義實(shí)體類(lèi):客戶(hù)類(lèi)、商品類(lèi)、訂單類(lèi)和訂單詳情類(lèi)

Starter類(lèi):
用于SpringBoot項(xiàng)目啟動(dòng)運(yùn)行
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
//掃描mapper接口所在的包
@MapperScan("com.hs.mapper")
public class Starter {
public static void main(String[] args) {
SpringApplication.run(Starter.class);
}
}5.在resources文件下配置yml文件(數(shù)據(jù)庫(kù)配置和日志配置)
#數(shù)據(jù)庫(kù)配置
spring:
datasource:
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/ssm2?useUnicode=true&useSSL=false&characterEncoding=utf8&serverTimezone=GMT%2B8
username: root
password: 123456
#添加日志配置項(xiàng)
mybatis-plus:
configuration:
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl6.在resources文件下創(chuàng)建mapper文件夾,在mapper下創(chuàng)建XML文件自定義數(shù)據(jù)庫(kù)操作功能實(shí)現(xiàn)
<?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" >二、實(shí)現(xiàn)訂單表和用戶(hù)表關(guān)聯(lián)查詢(xún)(一對(duì)一)
需求:關(guān)聯(lián)查詢(xún)其相關(guān)用戶(hù)信息
訂單表->用戶(hù)表:一個(gè)訂單只由一個(gè)用戶(hù)創(chuàng)建,一對(duì)一關(guān)系
做法:1.在Orders類(lèi)中加入U(xiǎn)sers屬性,Users屬性用于存儲(chǔ)關(guān)聯(lián)查詢(xún)的用戶(hù)信息。
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
@Data
@AllArgsConstructor
@NoArgsConstructor
public class Orders {
private Integer id;
private String orderNumber;
private Double totalPrice;
private String status;
private Integer userId;
/*
*多表查詢(xún):一對(duì)一關(guān)系
* 訂單表關(guān)聯(lián)查詢(xún)用戶(hù)表
* */
private Users users;
}2.在OrderMapper接口中,自定義功能實(shí)現(xiàn)
@Mapper
public interface OrderMapper extends BaseMapper<Orders> {
public List<Orders> selectUserResultMap();
}3.在resources文件下mapper文件夾里,書(shū)寫(xiě)映射下XML文件UserMapper
resultMap:需要單獨(dú)定義resultMap,使用 resultMap可以完成將關(guān)聯(lián)查詢(xún)映射到實(shí)體類(lèi)的屬性中。
association標(biāo)簽: 一對(duì)一關(guān)系映射描述。
- property: 關(guān)系屬性名稱(chēng)。
- javaType: 關(guān)系屬性類(lèi)型。
<resultMap id="selectUserResultMap" type="com.hs.pojo.Orders">
<id column="id" property="id"/>
<id column="order_number" property="orderNumber"/>
<id column="total_price" property="totalPrice"/>
<id column="status" property="status"/>
<association property="users" javaType="com.hs.pojo.Users">
<id column="user_id" property="id"/>
<id column="username" property="username"/>
<id column="password" property="password"/>
<id column="realname" property="realname"/>
</association>
</resultMap>
<select id="selectUserResultMap" resultType="com.hs.pojo.Orders">
select o.*,u.username,u.password,u.realname from orders o,users u where o.user_id=u.id
</select>4.在測(cè)試類(lèi)中進(jìn)行測(cè)試
@RunWith(SpringRunner.class)
@SpringBootTest(classes=Starter.class)
public class Test1 {
@Resource
private OrderMapper orderMapper;
//多表查詢(xún):一對(duì)一關(guān)系
//訂單表關(guān)聯(lián)查詢(xún)用戶(hù)表
@Test
public void selectOneByOne(){
List<Orders> orders = orderMapper.selectUserResultMap();
orders.forEach(System.out::println);
}
}三、實(shí)現(xiàn)訂單表和訂單詳情表關(guān)聯(lián)查詢(xún)(一對(duì)多)
需求:
- 關(guān)聯(lián)查詢(xún)其相關(guān)用戶(hù)信息。
- 關(guān)聯(lián)查詢(xún)其相關(guān)訂單詳情信息。
訂單表->訂單詳情表:一對(duì)多
具體做法同上。
1.在Orders類(lèi)中加入屬性ordersDetailList
/*
* 一對(duì)多關(guān)系屬性:一個(gè)訂單包含多個(gè)訂單詳情
* */
private List<OrderDetails> ordersDetailList;2.在OrderMapper接口中,自定義功能實(shí)現(xiàn)
/*
* 一對(duì)多:查詢(xún)訂單信息,
* 一個(gè)訂單對(duì)應(yīng)多條詳情信息,則是一對(duì)多
* */
public List<Orders> selectOrdersAndDetail();3.在resources文件下mapper文件夾里,書(shū)寫(xiě)映射下XML文件UserMapper
在Order類(lèi)中加入ordersDetailList屬性,details屬性用于存儲(chǔ)關(guān)聯(lián)查詢(xún)的訂單詳情。
collection標(biāo)簽: 一對(duì)多關(guān)系映射描述。
- property: 關(guān)系屬性名稱(chēng)。
- ofType: 關(guān)系屬性是一個(gè)List集合,集合中存放的元素類(lèi)型。
<!--
collection:一對(duì)多
property:訂單實(shí)體類(lèi)中的屬性
ofType:集合里面存儲(chǔ)的類(lèi)型
-->
<collection property="orderDetailList" ofType="com.hs.pojo.OrderDetails">
<id column="detail_id" property="id"/>
<id column="amount" property="amount"/>
<id column="orders_id" property="ordersId"/>
<id column="goods_id" property="goodsId"/>
</collection>
</resultMap>
<select id="selectOrdersAndDetail" resultMap="detailResultMap">
select
o.*,u.username,u.password,u.realname,d.id detail_id,d.amount,d.orders_id,d.goods_id
from orders o,users u,orders_detail d
where o.user_id=u.id and o.id=d.orders_id
</select>四、實(shí)現(xiàn)訂單表和商品表關(guān)聯(lián)查詢(xún)(多對(duì)多)
中間表:訂單詳情表
需求:
- 關(guān)聯(lián)查詢(xún)其相關(guān)用戶(hù)信息。
- 關(guān)聯(lián)查詢(xún)其相關(guān)訂單詳情信息。
- 關(guān)聯(lián)查詢(xún)訂單詳情中的商品信息。
訂單表->訂單詳情表:一對(duì)多 訂單詳情表->訂單表:一對(duì)一
訂單詳情表->商品表:一對(duì)一 商品表->訂單詳情表:一對(duì)多
訂單表->商品表:一對(duì)多 商品表->訂單表:多對(duì)一
做法:
1.在OrderDetails類(lèi)中加入屬性goods
2.在OrderMapper接口中,自定義功能實(shí)現(xiàn)
3.在resources文件下mapper文件夾里,書(shū)寫(xiě)映射下XML文件UserMappe
<resultMap id="goodsResultMap" type="com.hs.pojo.Orders">
<id column="id" property="id"/>
<id column="order_number" property="orderNumber"/>
<id column="total_price" property="totalPrice"/>
<id column="status" property="status"/>
<!--
collection:一對(duì)多映射
property:訂單實(shí)體類(lèi)中的屬性
ofType:集合里面存儲(chǔ)的類(lèi)型
-->
<collection property="orderDetailList" ofType="com.hs.pojo.OrderDetails">
<id column="detail_id" property="id"/>
<id column="amount" property="amount"/>
<id column="orders_id" property="ordersId"/>
<id column="goods_id" property="goodsId"/>
<association property="goods" javaType="com.hs.pojo.Goods">
<id column="goods_id" property="id"/>
<id column="goods_name" property="goodsName"/>
<id column="description" property="description"/>
<id column="price" property="price"/>
</association>
</collection>
</resultMap>
<select id="selectOrdersAndGoods" resultMap="goodsResultMap">
select
o.*,d.goods_id,g.goods_name,g.description,g.price
from orders o,orders_detail d,goods g
where o.id = d.orders_id and d.goods_id = g.id
</select>以上就是SpringBoot整合Mybatis-Plus實(shí)現(xiàn)關(guān)聯(lián)查詢(xún)的詳細(xì)內(nèi)容,更多關(guān)于SpringBoot Mybatis-Plus關(guān)聯(lián)查詢(xún)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- SpringBoot整合Mybatis-plus實(shí)現(xiàn)多級(jí)評(píng)論功能
- SpringBoot3整合mybatis-plus的實(shí)現(xiàn)
- Springboot3整合Mybatis-plus3.5.3報(bào)錯(cuò)問(wèn)題解決
- SpringBoot整合mybatis-plus實(shí)現(xiàn)分頁(yè)查詢(xún)功能
- springboot3.2整合mybatis-plus詳細(xì)代碼示例
- SpringBoot3和mybatis-plus整合出現(xiàn)的問(wèn)題解決辦法
- SpringBoot3.2.2整合MyBatis-Plus3.5.5依賴(lài)不兼容的問(wèn)題解決
- 全網(wǎng)最新springboot整合mybatis-plus的過(guò)程
- SpringBoot3.3.X整合Mybatis-Plus的實(shí)現(xiàn)示例
相關(guān)文章
解決報(bào)java.lang.AssertionError錯(cuò)誤的問(wèn)題
這篇文章主要介紹了解決報(bào)java.lang.AssertionError錯(cuò)誤的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05
淺談SpringCloud feign的http請(qǐng)求組件優(yōu)化方案
這篇文章主要介紹了淺談SpringCloud feign的http請(qǐng)求組件優(yōu)化方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-02-02
通過(guò)簡(jiǎn)易例子講解Java回調(diào)機(jī)制
這篇文章主要介紹了通過(guò)簡(jiǎn)易例子講解Java回調(diào)機(jī)制,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11
深入講解基于JDK的動(dòng)態(tài)代理機(jī)制
眾所周知相比于靜態(tài)代理,動(dòng)態(tài)代理避免了開(kāi)發(fā)人員編寫(xiě)各個(gè)繁鎖的靜態(tài)代理類(lèi),下面這篇文章主要給大家介紹了關(guān)于基于JDK的動(dòng)態(tài)代理機(jī)制的相關(guān)資料,文中通過(guò)圖文以及示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2018-07-07
Java中String類(lèi)的常見(jiàn)方法超詳細(xì)講解
這篇文章主要介紹了Java中String類(lèi)常見(jiàn)方法的相關(guān)資料,String類(lèi)是不可變的,字符串常量池用于存儲(chǔ)字符串字面量,常用方法包括字符串查找、轉(zhuǎn)換、比較、替換、拆分和截取,需要的朋友可以參考下2025-04-04
SpringBoot手動(dòng)開(kāi)啟事務(wù):DataSourceTransactionManager問(wèn)題
這篇文章主要介紹了SpringBoot手動(dòng)開(kāi)啟事務(wù):DataSourceTransactionManager問(wèn)題,具有很好的價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07

