亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時(shí)間:2024年08月08日 08:42:48   作者:晴梔_mm  
Mybatis-Plus(簡(jiǎn)稱(chēng)MP)是一個(gè)Mybatis的增強(qiáng)工具,只是在Mybatis的基礎(chǔ)上做了增強(qiáng)卻不做改變,MyBatis-Plus支持所有Mybatis原生的特性,本文給大家介紹了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.StdOutImpl

6.在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)文章!

相關(guān)文章

  • 解決報(bào)java.lang.AssertionError錯(cuò)誤的問(wè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)化方案

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

    史上最難的一道Java面試題

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

    RocketMQ順序消息的原理與特點(diǎn)

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

    深入講解基于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)方法超詳細(xì)講解

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

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

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

    Java停止線(xiàn)程的3種方法

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

    SpringBoot手動(dòng)開(kāi)啟事務(wù):DataSourceTransactionManager問(wèn)題

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

最新評(píng)論