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

SpringBoot3.0集成MybatisPlus的實(shí)現(xiàn)方法

 更新時(shí)間:2024年08月07日 15:08:07   作者:頑石九變  
本文主要介紹了SpringBoot3.0集成MybatisPlus的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

一、什么是 Mybatis Plus

MyBatis-Plus(簡(jiǎn)稱 MP)是一個(gè) MyBatis 的增強(qiáng)工具,在 MyBatis 的基礎(chǔ)上只做增強(qiáng)不做改變,為簡(jiǎn)化開發(fā)、提高效率而生。

特性

  • 無侵入:只做增強(qiáng)不做改變,引入它不會(huì)對(duì)現(xiàn)有工程產(chǎn)生影響,如絲般順滑
  • 損耗小:?jiǎn)?dòng)即會(huì)自動(dòng)注入基本 CURD,性能基本無損耗,直接面向?qū)ο蟛僮?/li>
  • 強(qiáng)大的 CRUD 操作:內(nèi)置通用 Mapper、通用 Service,僅僅通過少量配置即可實(shí)現(xiàn)單表大部分 CRUD 操作,更有強(qiáng)大的條件構(gòu)造器,滿足各類使用需求
  • 支持 Lambda 形式調(diào)用:通過 Lambda 表達(dá)式,方便的編寫各類查詢條件,無需再擔(dān)心字段寫錯(cuò)
  • 支持主鍵自動(dòng)生成:支持多達(dá) 4 種主鍵策略(內(nèi)含分布式唯一 ID 生成器 - Sequence),可自由配置,完美解決主鍵問題
  • 支持 ActiveRecord 模式:支持 ActiveRecord 形式調(diào)用,實(shí)體類只需繼承 Model 類即可進(jìn)行強(qiáng)大的 CRUD 操作
  • 支持自定義全局通用操作:支持全局通用方法注入( Write once, use anywhere )
  • 內(nèi)置代碼生成器:采用代碼或者 Maven 插件可快速生成 Mapper 、 Model 、 Service 、 Controller 層代碼,支持模板引擎,更有超多自定義配置等您來使用
  • 內(nèi)置分頁(yè)插件:基于 MyBatis 物理分頁(yè),開發(fā)者無需關(guān)心具體操作,配置好插件之后,寫分頁(yè)等同于普通 List 查詢
  • 分頁(yè)插件支持多種數(shù)據(jù)庫(kù):支持 MySQL、MariaDB、Oracle、DB2、H2、HSQL、SQLite、Postgre、SQLServer 等多種數(shù)據(jù)庫(kù)
  • 內(nèi)置性能分析插件:可輸出 SQL 語(yǔ)句以及其執(zhí)行時(shí)間,建議開發(fā)測(cè)試時(shí)啟用該功能,能快速揪出慢查詢
  • 內(nèi)置全局?jǐn)r截插件:提供全表 delete 、 update 操作智能分析阻斷,也可自定義攔截規(guī)則,預(yù)防誤操作

二、Spring Boot 3.0 集成 Mybatis Plus

1、 添加依賴

<dependency>
	<groupId>mysql</groupId>
	<artifactId>mysql-connector-java</artifactId>
</dependency>
<dependency>
	<groupId>com.alibaba</groupId>
	<artifactId>druid-spring-boot-starter</artifactId>
	<version>1.2.6</version>
</dependency>
<!-- mybatis plus -->
<dependency>
	<groupId>com.baomidou</groupId>
	<artifactId>mybatis-plus-boot-starter</artifactId>
	<version>3.5.5</version>
</dependency>
<dependency>
	<groupId>org.mybatis</groupId>
	<artifactId>mybatis-spring</artifactId>
	<version>3.0.3</version>
</dependency>

注意: SpringBoot 3.0 需要 mybatis-spring 3.0.X 版本,否則會(huì)報(bào)如下錯(cuò)誤:
Invalid value type for attribute 'factoryBeanObjectType'‘': java.lang.String

2、配置數(shù)據(jù)源

# druid 數(shù)據(jù)源配置
spring.datasource.url=jdbc:mysql://localhost:3306/your_db?useUnicode=true&characterEncoding=utf-8&allowMultiQueries=true&useSSL=false&serverTimezone=Asia/Shanghai
spring.datasource.username=root
spring.datasource.password=password
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
# 初始化大小,最小,最大
spring.datasource.druid.initial-size=5
spring.datasource.druid.min-idle=5
spring.datasource.druid.maxActive=20
# 配置間隔多久才進(jìn)行一次檢測(cè),檢測(cè)需要關(guān)閉的空閑連接,單位是毫秒
spring.datasource.druid.timeBetweenEvictionRunsMillis=60000
# 配置一個(gè)連接在池中最小生存的時(shí)間,單位是毫秒
spring.datasource.druid.minEvictableIdleTimeMillis=300000
spring.datasource.druid.validationQuery=SELECT 1
spring.datasource.druid.testWhileIdle=true
spring.datasource.druid.testOnBorrow=false
spring.datasource.druid.testOnReturn=false
spring.datasource.druid.stat-view-servlet.allow=true
spring.datasource.druid.web-stat-filter.enabled=true
spring.datasource.druid.web-stat-filter.url-pattern=/druid/*
spring.datasource.druid.filters=stat,wall,slf4j
spring.datasource.druid.connectionProperties=druid.stat.mergeSql\=true;druid.stat.slowSqlMillis\=5000

# --- mybatis-plus start
mybatis-plus.mapper-locations=classpath:/org/shi9/module/**/xml/*Mapper.xml
# 關(guān)閉MP3.0自帶的banner
mybatis-plus.global-config.banner=false
# 主鍵類型  0:"數(shù)據(jù)庫(kù)ID自增",1:"該類型為未設(shè)置主鍵類型", 2:"用戶輸入ID",3:"全局唯一ID (數(shù)字類型唯一ID)", 4:"全局唯一ID UUID",5:"字符串全局唯一ID (idWorker 的字符串表示)";
mybatis-plus.global-config.db-config.id-type=ASSIGN_ID
# 返回類型為Map,顯示null對(duì)應(yīng)的字段
mybatis-plus.configuration.call-setters-on-nulls=true
# 這個(gè)配置會(huì)將執(zhí)行的sql打印出來,在開發(fā)或測(cè)試的時(shí)候可以用
mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
# --- mybatis-plus end

3、創(chuàng)建實(shí)體類和 Mapper

創(chuàng)建你的實(shí)體類和對(duì)應(yīng)的 Mapper 接口。MyBatis Plus 會(huì)自動(dòng)掃描這些類并為你生成相應(yīng)的 Mapper 和 SQL 語(yǔ)句。你也可以使用 MyBatis Plus 的 CRUD 操作來簡(jiǎn)化開發(fā)。

這里以SysLog為例

SysLogMapper.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="org.shi9.module.system.mapper.SysLogMapper">
</mapper>

SysLogMapper.java

@Mapper
public interface SysLogMapper extends BaseMapper<SysLog> {
}

4、編寫 Service 類

public interface ISysLogService extends IService<SysLog> {
}

@Service
public class SysLogServiceImpl extends ServiceImpl<SysLogMapper, SysLog> implements ISysLogService {
}

5、編寫測(cè)試類

@Slf4j
@SpringBootTest
public class SysLogServiceTest {
    @Autowired
    private ISysLogService sysLogService;

    @Test
    public void findTotal(){
        Long total = sysLogService.count();
        System.out.println(total);
    }
}

三、Mybatis Plus 查詢示例

1、普通查詢

以下是使用 MyBatis Plus 進(jìn)行查詢的示例:

  • 根據(jù)主鍵查詢單個(gè)結(jié)果

使用 selectById 方法查詢單個(gè)結(jié)果:

User user = userMapper.selectById(1L);
  • 查詢多條記錄

使用 selectList 方法查詢多條記錄:

List<User> users = userMapper.selectList(null);
  • 使用 QueryWrapper 進(jìn)行查詢

可以使用 QueryWrapper 對(duì)查詢條件進(jìn)行組裝:

QueryWrapper<User> queryWrapper = new QueryWrapper<>();
queryWrapper.eq("name", "John").lt("age", 30);
List<User> userList = userMapper.selectList(queryWrapper);
  • 分頁(yè)查詢

使用 Page 類進(jìn)行分頁(yè)查詢:

Page<User> page = new Page<>(1, 10); // 第1頁(yè),每頁(yè)顯示10條記錄
QueryWrapper<User> queryWrapper = new QueryWrapper<>();
queryWrapper.eq("name", "John");
page.setFilter(queryWrapper);
Page<User> result = userMapper.selectPage(page, null);
  • 模糊查詢

使用 like 方法進(jìn)行模糊查詢:

QueryWrapper<User> queryWrapper = new QueryWrapper<>();
queryWrapper.like("name", "Jo");
List<User> userList = userMapper.selectList(queryWrapper);
  • 排序查詢

使用 orderBy 方法進(jìn)行排序查詢:

QueryWrapper<User> queryWrapper = new QueryWrapper<>();
queryWrapper.orderByDesc("age");
List<User> userList = userMapper.selectList(queryWrapper);
  • 聚合查詢

使用 groupBy 和 sum、count 等方法進(jìn)行聚合查詢:

QueryWrapper<User> queryWrapper = new QueryWrapper<>();
queryWrapper.groupBy("age");
Long totalCount = userMapper.selectSum(queryWrapper, "age");
  • 自定義 SQL

使用 @Select 注解自定義 SQL 語(yǔ)句:

@Select("SELECT * FROM user WHERE age > #{age}")
List<User> selectUsersByAge(@Param("age") Integer age);

這些示例只是 MyBatis Plus 提供的一些常見查詢方法的冰山一角。MyBatis Plus 還提供了很多其他功能和擴(kuò)展,可以根據(jù)需要進(jìn)行配置和使用。同時(shí),MyBatis Plus 還支持與其他組件的集成,例如分頁(yè)插件、樂觀鎖插件等,可以幫助你更加高效地進(jìn)行數(shù)據(jù)庫(kù)操作。

2、分頁(yè)查詢

MyBatis Plus 支持分頁(yè)功能,可以通過配置分頁(yè)插件來實(shí)現(xiàn)。分頁(yè)插件可以幫助我們自動(dòng)處理分頁(yè)相關(guān)的 SQL 語(yǔ)句,簡(jiǎn)化分頁(yè)邏輯。以下是使用分頁(yè)插件的步驟:

1、配置分頁(yè)插件

@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor() {
    MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
    // 配置分頁(yè)插件
    interceptor.addInnerInterceptor(new PaginationInnerInterceptor());
    // 增加@Version樂觀鎖支持
    interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());
    return interceptor;
}

2. 使用分頁(yè)插件

在 Mapper 接口或 XML 映射文件中使用分頁(yè)插件提供的查詢方法進(jìn)行分頁(yè)查詢。例如:

@Select("SELECT * FROM user WHERE 1=1")
Page<User> selectUserPage(Page<User> page);

在查詢方法上使用 Page 參數(shù),MyBatis Plus 會(huì)自動(dòng)處理分頁(yè)相關(guān)的 SQL 語(yǔ)句,返回包含分頁(yè)信息的 Page 對(duì)象。你可以根據(jù)需要配置查詢條件、排序規(guī)則等。

3. 處理分頁(yè)結(jié)果

根據(jù)返回的 Page 對(duì)象,你可以獲取當(dāng)前頁(yè)的數(shù)據(jù)、總記錄數(shù)、總頁(yè)數(shù)等信息,進(jìn)行相應(yīng)的業(yè)務(wù)處理。例如:

Page<User> page = userMapper.selectUserPage(new Page<>(1, 10)); // 第1頁(yè),每頁(yè)顯示10條記錄
List<User> userList = page.getRecords(); // 當(dāng)前頁(yè)的數(shù)據(jù)列表
int totalCount = page.getTotal(); // 總記錄數(shù)
int totalPage = page.getPages(); // 總頁(yè)數(shù)

通過這些步驟,你可以在 MyBatis Plus 中配置和使用分頁(yè)插件,簡(jiǎn)化分頁(yè)邏輯,提高開發(fā)效率。

參考

 到此這篇關(guān)于SpringBoot3.0集成MybatisPlus的實(shí)現(xiàn)方法的文章就介紹到這了,更多相關(guān)SpringBoot3.0集成MybatisPlus內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • JDBC的ResultSet使用說明

    JDBC的ResultSet使用說明

    今天小編就為大家分享一篇JDBC的ResultSet使用說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-02-02
  • 解決@Scheduled定時(shí)器使用@Thransactional事物問題

    解決@Scheduled定時(shí)器使用@Thransactional事物問題

    這篇文章主要介紹了解決@Scheduled定時(shí)器使用@Thransactional事物問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • 詳解Mybatis模板(已優(yōu)化)適合小白

    詳解Mybatis模板(已優(yōu)化)適合小白

    這篇文章主要介紹了Mybatis模板(已優(yōu)化)適合小白,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-03-03
  • SpringBoot中必須掌握的常用注解小結(jié)

    SpringBoot中必須掌握的常用注解小結(jié)

    Spring?Boot?提供了大量的注解,用于簡(jiǎn)化配置和加速程序開發(fā),這篇文章主要來和大家Spring?Boot中的常用注解的具體使用,希望對(duì)大家有所幫助
    2024-11-11
  • 原生java代碼實(shí)現(xiàn)碼云第三方驗(yàn)證登錄的示例代碼

    原生java代碼實(shí)現(xiàn)碼云第三方驗(yàn)證登錄的示例代碼

    這篇文章主要介紹了原生java代碼實(shí)現(xiàn)碼云第三方驗(yàn)證登錄的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • RocketMQ?源碼分析Broker消息刷盤服務(wù)

    RocketMQ?源碼分析Broker消息刷盤服務(wù)

    這篇文章主要為大家介紹了RocketMQ?源碼分析Broker消息刷盤服務(wù)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • Spring?Boot中自動(dòng)執(zhí)行sql腳本的方法實(shí)例

    Spring?Boot中自動(dòng)執(zhí)行sql腳本的方法實(shí)例

    在SpringBoot的架構(gòu)中,DataSourceInitializer類可以在項(xiàng)目啟動(dòng)后初始化數(shù)據(jù),我們可以通過自動(dòng)執(zhí)行自定義sql腳本初始化數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于Spring?Boot中自動(dòng)執(zhí)行sql腳本的相關(guān)資料,需要的朋友可以參考下
    2022-01-01
  • Spring4.0 MVC請(qǐng)求json數(shù)據(jù)報(bào)406錯(cuò)誤的解決方法

    Spring4.0 MVC請(qǐng)求json數(shù)據(jù)報(bào)406錯(cuò)誤的解決方法

    這篇文章主要為大家詳細(xì)介紹了Spring4.0 MVC請(qǐng)求json數(shù)據(jù)報(bào)406錯(cuò)誤的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • 一文詳解如何在控制臺(tái)顯示MyBatis的SQL語(yǔ)句

    一文詳解如何在控制臺(tái)顯示MyBatis的SQL語(yǔ)句

    這篇文章主要為大家介紹了如何在控制臺(tái)顯示MyBatis的SQL語(yǔ)句實(shí)現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • 在?Spring?Boot?中使用?Quartz?調(diào)度作業(yè)的示例詳解

    在?Spring?Boot?中使用?Quartz?調(diào)度作業(yè)的示例詳解

    這篇文章主要介紹了在?Spring?Boot?中使用?Quartz?調(diào)度作業(yè)的示例詳解,在本文中,我們將看看如何使用Quartz框架來調(diào)度任務(wù),Quartz支持在特定時(shí)間運(yùn)行作業(yè)、重復(fù)作業(yè)執(zhí)行、將作業(yè)存儲(chǔ)在數(shù)據(jù)庫(kù)中以及Spring集成,需要的朋友可以參考下
    2022-07-07

最新評(píng)論