欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot整合Mybatis-Plus實現(xiàn)關(guān)聯(lián)查詢

 更新時間:2024年08月08日 08:42:48   作者:晴梔_mm  
Mybatis-Plus(簡稱MP)是一個Mybatis的增強(qiáng)工具,只是在Mybatis的基礎(chǔ)上做了增強(qiáng)卻不做改變,MyBatis-Plus支持所有Mybatis原生的特性,本文給大家介紹了SpringBoot整合Mybatis-Plus實現(xiàn)關(guān)聯(lián)查詢,需要的朋友可以參考下

一、搭建環(huán)境

1.創(chuàng)建Maven普通項目

2.添加依賴坐標(biāo)

<parent>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-parent</artifactId>
 <version>2.2.2.RELEASE</version>
</parent>
 
<dependencies>
    <!--單元測試-->
    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-test</artifactId>
    </dependency>
 
    <!-- 數(shù)據(jù)庫驅(qū)動 -->
    <!--mysql驅(qū)動-->
    <dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
   <!-- <version>8.0.19</version>-->
    </dependency>
 
    <!-- lombok 簡化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包和啟動類Starter

mapper包: 

 在該包下定接口繼承BaseMapper接口

pojo包:

在該包下定義實體類:客戶類、商品類、訂單類和訂單詳情類

Starter類:

用于SpringBoot項目啟動運行

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ù)庫配置和日志配置)

#數(shù)據(jù)庫配置
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
 
#添加日志配置項
mybatis-plus:
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

6.在resources文件下創(chuàng)建mapper文件夾,在mapper下創(chuàng)建XML文件自定義數(shù)據(jù)庫操作功能實現(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" >

二、實現(xiàn)訂單表和用戶表關(guān)聯(lián)查詢(一對一)

需求:關(guān)聯(lián)查詢其相關(guān)用戶信息

訂單表->用戶表:一個訂單只由一個用戶創(chuàng)建,一對一關(guān)系

做法:1.在Orders類中加入Users屬性,Users屬性用于存儲關(guān)聯(lián)查詢的用戶信息。

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;
    /*
    *多表查詢:一對一關(guān)系
    * 訂單表關(guān)聯(lián)查詢用戶表
    * */
    private Users users;
}

2.在OrderMapper接口中,自定義功能實現(xiàn)

@Mapper
public interface OrderMapper extends BaseMapper<Orders> {
    public List<Orders> selectUserResultMap();
}

3.在resources文件下mapper文件夾里,書寫映射下XML文件UserMapper

resultMap:需要單獨定義resultMap,使用 resultMap可以完成將關(guān)聯(lián)查詢映射到實體類的屬性中。

association標(biāo)簽: 一對一關(guān)系映射描述。

  • property: 關(guān)系屬性名稱。
  • javaType: 關(guān)系屬性類型。
 <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.在測試類中進(jìn)行測試

@RunWith(SpringRunner.class)
@SpringBootTest(classes=Starter.class)
public class Test1 {
    @Resource
    private OrderMapper orderMapper;
    //多表查詢:一對一關(guān)系
    //訂單表關(guān)聯(lián)查詢用戶表
    @Test
    public void selectOneByOne(){
        List<Orders> orders = orderMapper.selectUserResultMap();
        orders.forEach(System.out::println);
    }
}

三、實現(xiàn)訂單表和訂單詳情表關(guān)聯(lián)查詢(一對多)

需求:

  • 關(guān)聯(lián)查詢其相關(guān)用戶信息。
  • 關(guān)聯(lián)查詢其相關(guān)訂單詳情信息。

訂單表->訂單詳情表:一對多 

具體做法同上。

1.在Orders類中加入屬性ordersDetailList

 /*
     * 一對多關(guān)系屬性:一個訂單包含多個訂單詳情
     * */
    private List<OrderDetails> ordersDetailList;

2.在OrderMapper接口中,自定義功能實現(xiàn)

    /*
    * 一對多:查詢訂單信息,
    * 一個訂單對應(yīng)多條詳情信息,則是一對多
    * */
 
    public List<Orders> selectOrdersAndDetail();

3.在resources文件下mapper文件夾里,書寫映射下XML文件UserMapper 

在Order類中加入ordersDetailList屬性,details屬性用于存儲關(guān)聯(lián)查詢的訂單詳情。

collection標(biāo)簽: 一對多關(guān)系映射描述。

  • property: 關(guān)系屬性名稱。
  • ofType: 關(guān)系屬性是一個List集合,集合中存放的元素類型。
    <!--
        collection:一對多
        property:訂單實體類中的屬性
        ofType:集合里面存儲的類型
        -->
 
        <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>

四、實現(xiàn)訂單表和商品表關(guān)聯(lián)查詢(多對多)

中間表:訂單詳情表

需求:

  • 關(guān)聯(lián)查詢其相關(guān)用戶信息。
  • 關(guān)聯(lián)查詢其相關(guān)訂單詳情信息。
  • 關(guān)聯(lián)查詢訂單詳情中的商品信息。

訂單表->訂單詳情表:一對多     訂單詳情表->訂單表:一對一

訂單詳情表->商品表:一對一      商品表->訂單詳情表:一對多

訂單表->商品表:一對多                 商品表->訂單表:多對一

做法:

1.在OrderDetails類中加入屬性goods

2.在OrderMapper接口中,自定義功能實現(xiàn)

3.在resources文件下mapper文件夾里,書寫映射下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:一對多映射
        property:訂單實體類中的屬性
        ofType:集合里面存儲的類型
        -->
        <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實現(xiàn)關(guān)聯(lián)查詢的詳細(xì)內(nèi)容,更多關(guān)于SpringBoot Mybatis-Plus關(guān)聯(lián)查詢的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 解決報java.lang.AssertionError錯誤的問題

    解決報java.lang.AssertionError錯誤的問題

    這篇文章主要介紹了解決報java.lang.AssertionError錯誤的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • 淺談SpringCloud feign的http請求組件優(yōu)化方案

    淺談SpringCloud feign的http請求組件優(yōu)化方案

    這篇文章主要介紹了淺談SpringCloud feign的http請求組件優(yōu)化方案,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-02-02
  • 通過簡易例子講解Java回調(diào)機(jī)制

    通過簡易例子講解Java回調(diào)機(jī)制

    這篇文章主要介紹了通過簡易例子講解Java回調(diào)機(jī)制,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-11-11
  • 史上最難的一道Java面試題

    史上最難的一道Java面試題

    本文給大家分享一道史上最難的一道Java面試題,非常不錯,具有參考借鑒價值,需要的朋友參考下吧
    2018-03-03
  • RocketMQ順序消息的原理與特點

    RocketMQ順序消息的原理與特點

    RocketMQ作為一款純java、分布式、隊列模型的開源消息中間件,支持事務(wù)消息、順序消息、批量消息、定時消息、消息回溯等,本篇我們了解如何實現(xiàn)順序消息的原理與特點
    2023-02-02
  • 深入講解基于JDK的動態(tài)代理機(jī)制

    深入講解基于JDK的動態(tài)代理機(jī)制

    眾所周知相比于靜態(tài)代理,動態(tài)代理避免了開發(fā)人員編寫各個繁鎖的靜態(tài)代理類,下面這篇文章主要給大家介紹了關(guān)于基于JDK的動態(tài)代理機(jī)制的相關(guān)資料,文中通過圖文以及示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2018-07-07
  • Java中String類的常見方法超詳細(xì)講解

    Java中String類的常見方法超詳細(xì)講解

    這篇文章主要介紹了Java中String類常見方法的相關(guān)資料,String類是不可變的,字符串常量池用于存儲字符串字面量,常用方法包括字符串查找、轉(zhuǎn)換、比較、替換、拆分和截取,需要的朋友可以參考下
    2025-04-04
  • Java內(nèi)存分布?xì)w納整理詳解

    Java內(nèi)存分布?xì)w納整理詳解

    這篇文章主要介紹了java程序運行時內(nèi)存分布詳解,需要的朋友可以參考下
    2017-04-04
  • Java停止線程的3種方法

    Java停止線程的3種方法

    這篇文章主要分享Java停止線程的3種方法,分別是自定義中斷標(biāo)識符,停止線程、使用線程中斷方法interrupt停止線程、使用stop停止線程。下文詳細(xì)介紹需要的小伙伴可以參考一下
    2022-05-05
  • SpringBoot手動開啟事務(wù):DataSourceTransactionManager問題

    SpringBoot手動開啟事務(wù):DataSourceTransactionManager問題

    這篇文章主要介紹了SpringBoot手動開啟事務(wù):DataSourceTransactionManager問題,具有很好的價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07

最新評論