Spring Boot —— 集成 MyBatis-Plus

来源:https://www.cnblogs.com/cinlap/p/18202071
-Advertisement-
Play Games

項目基於 Spring Boot 3.2.5 Pom 需要註意的是,引用 Mybatis-Plus 依賴,無需手動引入 Mybatis <!-- https://mvnrepository.com/artifact/com.mysql/mysql-connector-j --> <dependenc ...


項目基於 Spring Boot 3.2.5

Pom

需要註意的是,引用 Mybatis-Plus 依賴,無需手動引入 Mybatis

<!-- https://mvnrepository.com/artifact/com.mysql/mysql-connector-j -->
<dependency>
    <groupId>com.mysql</groupId>
    <artifactId>mysql-connector-j</artifactId>
    <version>8.4.0</version>
</dependency>

<!-- mybatis-plus -->
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-spring-boot3-starter</artifactId>
    <version>3.5.6</version>
</dependency>

<!-- mybatis-plus-generator -->
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-generator</artifactId>
    <version>3.5.6</version>
</dependency>

<!-- mybatis-plus 自動生成時使用的模板-->
<dependency>
    <groupId>org.apache.velocity</groupId>
    <artifactId>velocity-engine-core</artifactId>
    <version>2.3</version>
</dependency>

application.yml

spring:
  profiles:
    active: develop

application-develop.yml

mybatis-plus:
  # mybatis xml 文件的保存路徑,classpath 表示 java 或 resources 目錄,因此當前設置表示 resources/mapper/任意子目錄/*Mapper.xml 文件都會被掃描
  mapper-locations: classpath:mapper/**/*Mapper.xml
  # 表示實體對象所在的命名空間
  type-aliases-package: com.cash216.mango.*.entity
  # mybatis-plus 配置文件,可選
  # config-location: classpath: config/MyBatisConfig.xml
  configuration:
    # 日誌輸出方式
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
  global-config:
    db-config:
      # 邏輯刪除配置
      logic-delete-value: 1
      logic-not-delete-value: 0
      logic-delete-field: del_flag

自動生成Service、Model(Entity)、Mapper

引入mybatis-plus-generator可用於基於資料庫自動生成各層文件,基本步驟如下:

  • 引入依賴
  • 配置數據連接
  • 編寫自動生成運行代碼
  • 完善自動生成文件業務邏輯

引入依賴

在 pom 節已列舉,不再重覆

配置數據連接

application-develop.yml為例

spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.driver
	url: jdcb:mysql://127.0.0.1:3306/{database}?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=Asia/Shanghai&autoReconnect=true
	username: root
	password: 123456

實際這一步不影響自動生成,因為在編寫自動生成運行代碼時還需要設置

編寫自動生成文件的運行代碼

新建java文件如CodeGenerator.java,編寫代碼如下:

package com.cash216.mangoAdmin.codegenerator;

import com.baomidou.mybatisplus.annotation.FieldFill;
import com.baomidou.mybatisplus.core.exceptions.MybatisPlusException;
import com.baomidou.mybatisplus.generator.FastAutoGenerator;
import com.baomidou.mybatisplus.generator.fill.Column;

import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import java.util.Scanner;

public class CodeGenerator {

    private static final String databaseUrl = "jdbc:mysql://127.0.0.1:3306/{database}?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=Asia/Shanghai&autoReconnect=true";
    private static final String databaseUser = "root";
    private static final String databasePassword = "123456";

    public static String scanner(String tip){
        Scanner scanner = new Scanner(System.in);
        StringBuilder help = new StringBuilder();
        help.append("請輸入").append(tip).append(":");
        System.out.println(help.toString());
        if (scanner.hasNext()) {
            String ipt = scanner.next();
            if (ipt != null && !ipt.isEmpty()) {
                return ipt;
            }
        }
        throw new MybatisPlusException(STR."請輸入正確的\{tip}");
    }

    public static void main(String[] args){
		// 本例使用 Mybatis-plus 互動式生成方式,會詢問作者、包名、表名後自動生成各層目錄及文件
        FastAutoGenerator.create(databaseUrl, databaseUser, databasePassword)
                .globalConfig((scanner, builder)->
                        builder.author(scanner.apply("請輸入作者名稱"))
                                .commentDate("yyyy-MM-dd")
								// System.getProperty("user.dir") 表示整個項目的根目錄
                                .outputDir(System.getProperty("user.dir") + "/mango-admin/src/main/java"))
                .packageConfig((scanner, builder)-> builder.parent(scanner.apply("請輸入包名")))
                .strategyConfig((scanner, builder)-> builder.addInclude(getTables(scanner.apply("請輸入表名,多個英文逗號分隔,所有輸入 all")))
                        .entityBuilder()
                        .enableLombok()
                        .addTableFills(new Column("create_time", FieldFill.INSERT))
                        .build())
                .execute();
    }

    protected static List<String> getTables(String tables){
        return "all".equals(tables) ? Collections.emptyList() : Arrays.asList(tables.split(","));
    }
}

運行main方法,在控制台會以交互方式詢問作者、包名、表名後生成文件,需要註意的是,在本例中,使用outputDir(System.getProperty("user.dir") + "/mango-admin/src/main/java")控制生成文件的輸出目錄,user.dir返回當前工作目錄在本例運行時就是整個項目的根目錄, 生成後的效果如圖
image
image
image
image

完善業務代碼

本來*Mapper.xml文件是生成在mapper/xml目錄下的,在本例中是後移動到resources/mapper/system中,當然也可以不移動,配置文件中mapper-locations: classpath:mapper/**/*Mapper.xml可以找到。
另外,自動生成的Mapper介面需要增加依賴註入被SpringBoot管理,方法(至少)有兩種,第一種在Mapper介面文件上增加@Mapper註解,這種方式如果介面文件很多會不方便容易遺漏,第二種增加一個配置類,使用@MapperScan指定要掃描的包下的Mapper介面,代碼如下:

@Configuration
@MapperScan("com.cash216.mango.admin.mapper")
public class MyBatisConfig {
}

主要是@MapperScan起作用,MyBatisConfig類中甚至可以是空的

使用

不知道是本來就這樣還是我使用有問題,生成的所有文件,除了實體對象外,其他文件裡邊都是空的

Mybatis-plus 自帶一些通用介面方法,可直接調用,比如根據Id查詢記錄

public class SysUserServiceImpl extends ServiceImpl<SysUserMapper, SysUser> implements ISysUserService {
	@Override
	public SysUser findById(Long id){
		return baseMapper.selectById(id);
	}
}

Mybatis-plus 沒有的方法需自行添加實現,需要添加Mapper.xml、Mapper介面文件、IService、ServiceImpl、Controller,在這裡只列出ServiceImpl中的代碼為例

public class SysUserServiceImpl extends ServiceImpl<SysUserMapper, SysUser> implements ISysUserService {
	@Override
	public SysUser findById(Long id){
		return baseMapper.selectById(id);
	}
	
	@Override
	public SysUser findByName(String name){
		return baseMapper.selectOne(new QueryWrapper<SysUser>().eq("name", name));
	}
}

不重要的其實最重要

作者 - 試試手氣

轉載請註明作者和出處 - https://www.cnblogs.com/cinlap/p/18202071


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1. Spring 對 Junit4,Junit5 的支持上的運用 @目錄1. Spring 對 Junit4,Junit5 的支持上的運用每博一文案2. Spring對Junit4 的支持3. Spring對Junit5的支持4. 總結:5. 最後: 每博一文案 關於理想主義,在知乎上看到一句話: ...
  • >>上一篇(文科生在三本院校,讀電腦專業) 2015年9月,我入學了。 我期待的大學生活是多姿多彩的,我會參加各種社團,參與各種有意思的活動。 但我是個社恐,有過嘗試,但還是難以融入各種社交活動。 學習,我是有想過的。 學校開設的C++課程已經上了一段時間,但我無法理解雙層for迴圈執行過程、亦無 ...
  • title: Django性能優化:提升載入速度 date: 2024/5/20 20:16:28 updated: 2024/5/20 20:16:28 categories: 後端開發 tags: 緩存策略 HTTP請求 DNS查詢 CDN分發 前端優化 伺服器響應 瀏覽器緩存 第一章:Djan ...
  • 本文介紹了NumPy中的數組排序和過濾功能。`np.sort()`函數用於對數組進行升序排序,對二維數組則按行排序。示例展示瞭如何對一維和二維數組排序。此外,還講解了使用布爾索引來過濾數組,以及直接在條件中操作數組以創建過濾後的數組。最後,介紹了NumPy的隨機數生成,包括整數、浮點數及特定分佈的隨... ...
  • 1:打開cmd/Anaconda Prompt/Anaconda Powershell Prompt 2:進入虛擬環境conda activate 環境名 3:conda list查看有無ipykernel包 如果沒有,安裝兩個包:conda install nb_conda conda insta ...
  • 當某些合作商希望把你的keycloak作為他們的一種第三方登錄方式時,就像微信,google,github,使用你的keycloak上的賬戶資源時,你就需要考慮如何做一個開放的,標準的文檔了。 一 基本角色 認證提供者:keycloak服務,https://kc.xxx.com 第三方應用:先到ke ...
  • 本文深入探討了Kubernetes中的Pod調度機制,包括基礎概念、高級調度技術和實際案例分析。文章詳細介紹了Pod調度策略、Taints和Tolerations、節點親和性,以及如何在高流量情況下優化Pod調度和資源管理。 關註【TechLeadCloud】,分享互聯網架構、雲服務技術的全維度知識 ...
  • PPT是傳遞信息、進行彙報和推廣產品的重要工具。然而,有時我們需要將這些精心設計的PPT演示文稿發佈到網路上,以便於更廣泛的訪問和分享。本文將介紹如何使用Python將PowerPoint文檔轉換為網頁友好的HTML格式。包含兩個簡單示例: Python 將PowerPoint文檔轉為HTML格式 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...