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

SpringBoot整合MybatisPlus的基本應(yīng)用詳解

 更新時(shí)間:2024年05月16日 09:52:48   作者:哈__  
MyBatis-Plus (簡(jiǎn)稱 MP)是一個(gè) MyBatis的增強(qiáng)工具,在 MyBatis 的基礎(chǔ)上只做增強(qiáng)不做改變,為 簡(jiǎn)化開發(fā)、提高效率而生,本文將給大家介紹一下SpringBoot整合MybatisPlus的基本應(yīng)用,需要的朋友可以參考下

一、MybatisPlus簡(jiǎn)介

先來看一下官方的簡(jiǎn)介吧。

MyBatis-Plus (簡(jiǎn)稱 MP)是一個(gè) MyBatis的增強(qiáng)工具,在 MyBatis 的基礎(chǔ)上只做增強(qiáng)不做改變,為 簡(jiǎn)化開發(fā)、提高效率而生。Mybatis-Plus提供了通用的Mapper和Service,可以在不編寫任何SQL語(yǔ)句的前提下,快速的實(shí)現(xiàn)單表的增刪改查(CURD),批量,邏輯刪除,分頁(yè)等操作。只要把MyBatis-Plus的特性到優(yōu)秀插件,以及多數(shù)據(jù)源的配置進(jìn)行詳細(xì)講解。

我們的愿景是成為 MyBatis 最好的搭檔,就像魂斗羅中的 1P、2P ,基友搭配,效率翻倍。

MybatisPlus的特性 

  • 無侵入:只做增強(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ù)防誤操作

想要更多的了解MybatisPlus,可以到官網(wǎng)去看一下 MyBatis-Plus (baomidou.com)

我們直接上手講解SpringBoot項(xiàng)目如何整合MybatisPlus。

二、SpringBoot整合MybatisPlus 

1、創(chuàng)建數(shù)據(jù)庫(kù)和表

CREATE DATABASE `mybatis_plus` /*!40100 DEFAULT CHARACTER SET utf8mb4 */; use `mybatis_plus`;
CREATE TABLE `user` (
`id` bigint(20) NOT NULL COMMENT '主鍵ID',
`name` varchar(30) DEFAULT NULL COMMENT '姓名 ',
`age` int(11) DEFAULT NULL COMMENT '年齡 ',
`email` varchar(50) DEFAULT NULL COMMENT '郵箱 ',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

2.添加數(shù)據(jù)

INSERT INTO user (id, name, age, email) VALUES
(1, 'Jone', 18, 'test1@baomidou.com'),
(2, 'Jack', 20, 'test2@baomidou.com'),
(3, 'Tom', 28, 'test3@baomidou.com'),
(4, 'Sandy', 21, 'test4@baomidou.com'),
(5, 'Billie', 24, 'test5@baomidou.com');

3.創(chuàng)建一個(gè)SpringBoot項(xiàng)目

因?yàn)槲覜]有配置阿里的服務(wù)器,所以創(chuàng)建的springboot項(xiàng)目沒有Java8版本,我是后期自己修改的,并且使用springboot2.7.16版本,大家可以配置一下服務(wù)器URL。之后就可以創(chuàng)建8版本了。

https://start.aliyun.com

項(xiàng)目結(jié)構(gòu)。 我把a(bǔ)pplication.properties文件修改為了yml格式。

4.導(dǎo)入依賴

如果想要使用lombok插件需要在設(shè)置中找到插件,下載lombok插件。lombok可以簡(jiǎn)化我們的開發(fā)。

        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.5.2</version>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.5</version>
        </dependency>

創(chuàng)建我們需要的包。

5.修改application.yml文件

這里的密碼需要根據(jù)你自己的情況修改。

spring:
  # 配置數(shù)據(jù)源信息
  datasource:
  # 配置連接數(shù)據(jù)庫(kù)信息
    driver-class-name: com.mysql.jdbc.Driver
    url: jdbc:mysql://localhost:3306/mybatis_plus?characterEncoding=utf-8&useSSL=false
    username: root
    password: 2020

6.創(chuàng)建實(shí)體User的類 

在domain目錄下創(chuàng)建User類。

@Data
public class User {
    //設(shè)定id自增
    @TableId(type = IdType.AUTO)
    private Integer id;
    private String name;
    private Integer age;
    private String email;
}

7.添加mapper

在mapper目錄下創(chuàng)建UserMapper。UserMapper繼承BaseMapper,BaseMapper中封裝著一些基本的增刪改查操作,這樣就不用我們?cè)谧约簩慸ao層了。

@Mapper
public interface UserMapper extends BaseMapper<User> {
}

三、基本的CRUD操作

我們?cè)趖est方法中實(shí)現(xiàn)測(cè)試。

1.查詢所有用戶

調(diào)用selectList()方法,方法需要傳入一個(gè)參數(shù)queryWrapper,queryWrapper相當(dāng)于sql語(yǔ)句中的一些限制條件(這里不必在意我的輸出結(jié)果,數(shù)據(jù)庫(kù)的表格我已經(jīng)變動(dòng)過了,大家只要有輸出即可)。

@Test
    void getAllUser(){
        List<User> users = userMapper.selectList(null);
        for (User user : users) {
            System.out.println(user);
        }
    }

2.插入用戶 

這里可能會(huì)報(bào)錯(cuò),提示id不存在,我們要把數(shù)據(jù)庫(kù)當(dāng)中的id字段改為自動(dòng)遞增。

 @Test
    public void testInsert(){
        User user = new User(null, "哈__", 23, "ha@test.com");
        //INSERT INTO user ( id, name, age, email ) VALUES ( ?, ?, ?, ? )
        int result = userMapper.insert(user);
        System.out.println("受影響行數(shù):"+result);
        System.out.println("id自動(dòng)獲?。?+user.getId());
    }

3.刪除用戶

@Test
    public void testDeleteById(){
        //通過id刪除用戶信息
        //DELETE FROM user WHERE id=?
        int result = userMapper.deleteById(9);
        System.out.println("受影響行數(shù):"+result);
    }

4.更新用戶 

根據(jù)傳入的user的id更新,如果user中的某些字段為null,那么mybatisplus不會(huì)把值為null的屬性向數(shù)據(jù)庫(kù)進(jìn)行更新。

@Test
    public void testUpdateById(){
        User user = new User(1, "admin", 22, null);
        //UPDATE user SET name=?, age=? WHERE id=?
        int result = userMapper.updateById(user);
        System.out.println("受影響行數(shù):"+result);
    }

5.添加MybatisPlus日志

在application.yml文件當(dāng)中寫入如下配置。

mybatis-plus:
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

看效果。

四、service封裝mapper

在service包下創(chuàng)建IUserService接口。并創(chuàng)建impl包,在service.impl包下創(chuàng)建UserServiceImpl。

public interface IUserService extends IService<User> {
}
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements IUserService{
}

通過service調(diào)用mapper。MybatisPlus官方已經(jīng)幫我們封裝好了。

1.查詢所有用戶

 @Resource
    UserServiceImpl userService;
    @Test
    void getAllUser(){
        List<User> users = userService.list();
        for (User user : users) {
            System.out.println(user);
        }
    }

其他的就不在展示了,大家可以自己探索一下。 

 五、BaseMapper常用方法

package com.baomidou.mybatisplus.core.mapper;
 
public interface BaseMapper<T> extends Mapper<T> {
 
/**
* 插入一條記錄
* @param entity 實(shí)體對(duì)象 */
int insert(T entity);
 
/**
* 根據(jù) ID 刪除
* @param id 主鍵ID */
int deleteById(Serializable id);
 
/**
* 根據(jù)實(shí)體(ID)刪除
* @param entity 實(shí)體對(duì)象
* @since 3.4.4 */
int deleteById(T entity);
 
/**
* 根據(jù) columnMap 條件,刪除記錄
* @param columnMap 表字段 map 對(duì)象 */
int deleteByMap(@Param(Constants.COLUMN_MAP) Map<String, Object> columnMap);
 
/**
* 根據(jù) entity 條件,刪除記錄
* @param queryWrapper 實(shí)體對(duì)象封裝操作類(可以為 null,里面的 entity 用于生成 where
語(yǔ)句)
*/
int delete(@Param(Constants.WRAPPER) Wrapper<T> queryWrapper);
 
/**
* 刪除(根據(jù)ID 批量刪除)
* @param idList 主鍵ID列表(不能為 null 以及 empty) */
int deleteBatchIds(@Param(Constants.COLLECTION) Collection<? extends Serializable> idList);
 
/**
* 根據(jù) ID 修改
* @param entity 實(shí)體對(duì)象 */
int updateById(@Param(Constants.ENTITY) T entity);
 
/**
* 根據(jù) whereEntity 條件,更新記錄
* @param entity        實(shí)體對(duì)象 (set 條件值 ,可以為 null)
* @param updateWrapper 實(shí)體對(duì)象封裝操作類(可以為 null,里面的 entity 用于生成
where 語(yǔ)句)
*/
int update(@Param(Constants.ENTITY) T entity, @Param(Constants.WRAPPER) Wrapper<T> updateWrapper);
 
/**
* 根據(jù) ID 查詢
* @param id 主鍵ID */
T selectById(Serializable id);
 
/**
* 查詢(根據(jù)ID 批量查詢)
* @param idList 主鍵ID列表(不能為 null 以及 empty) */
List<T> selectBatchIds(@Param(Constants.COLLECTION) Collection<? extends Serializable> idList);
 
/**
* 查詢(根據(jù) columnMap 條件)
* @param columnMap 表字段 map 對(duì)象 */
List<T> selectByMap(@Param(Constants.COLUMN_MAP) Map<String, Object> columnMap);
 
/**
* 根據(jù) entity 條件,查詢一條記錄
* <p>查詢一條記錄,例如 qw.last("limit 1") 限制取一條記錄 , 注意:多條數(shù)據(jù)會(huì)報(bào)異常 </p>
* @param queryWrapper 實(shí)體對(duì)象封裝操作類(可以為 null)
*/
default T selectOne(@Param(Constants.WRAPPER) Wrapper<T> queryWrapper) { List<T> ts = this.selectList(queryWrapper);
if (CollectionUtils.isNotEmpty(ts)) {
if (ts.size() != 1) {
throw ExceptionUtils.mpe("One record is expected, but the query result is multiple records");
}
return ts.get(0);
}
return null;
}
 
/**
* 根據(jù) Wrapper 條件,查詢總記錄數(shù)
* @param queryWrapper 實(shí)體對(duì)象封裝操作類(可以為 null) */
Long selectCount(@Param(Constants.WRAPPER) Wrapper<T> queryWrapper);
 
/**
* 根據(jù) entity 條件,查詢?nèi)坑涗?
* @param queryWrapper 實(shí)體對(duì)象封裝操作類(可以為 null) */
List<T> selectList(@Param(Constants.WRAPPER) Wrapper<T> queryWrapper);
 
/**
* 根據(jù) Wrapper 條件,查詢?nèi)坑涗?
* @param queryWrapper 實(shí)體對(duì)象封裝操作類(可以為 null) */
List<Map<String, Object>> selectMaps(@Param(Constants.WRAPPER) Wrapper<T> queryWrapper);
 
/**
* 根據(jù) Wrapper 條件,查詢?nèi)坑涗?
* <p>注意: 只返回第一個(gè)字段的值</p>
* @param queryWrapper 實(shí)體對(duì)象封裝操作類(可以為 null) */
List<Object> selectObjs(@Param(Constants.WRAPPER) Wrapper<T> queryWrapper);
 
/**
* 根據(jù) entity 條件,查詢?nèi)坑涗洠ú⒎?yè))
* @param page         分頁(yè)查詢條件(可以為 RowBounds.DEFAULT)
* @param queryWrapper 實(shí)體對(duì)象封裝操作類(可以為 null) */
<P extends IPage<T>> P selectPage(P page, @Param(Constants.WRAPPER) Wrapper<T> queryWrapper);
 
/**
* 根據(jù) Wrapper 條件,查詢?nèi)坑涗洠ú⒎?yè))
* @param page         分頁(yè)查詢條件
* @param queryWrapper 實(shí)體對(duì)象封裝操作類 */
<P extends IPage<Map<String, Object>>> P selectMapsPage(P page, @Param(Constants.WRAPPER) Wrapper<T> queryWrapper);

以上就是SpringBoot整合MybatisPlus的基本應(yīng)用詳解的詳細(xì)內(nèi)容,更多關(guān)于SpringBoot整合MybatisPlus的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Java基本類型與byte數(shù)組之間相互轉(zhuǎn)換方法

    Java基本類型與byte數(shù)組之間相互轉(zhuǎn)換方法

    下面小編就為大家?guī)硪黄狫ava基本類型與byte數(shù)組之間相互轉(zhuǎn)換方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-08-08
  • Java Web使用Html5 FormData實(shí)現(xiàn)多文件上傳功能

    Java Web使用Html5 FormData實(shí)現(xiàn)多文件上傳功能

    這篇文章主要介紹了Java Web使用Html5 FormData實(shí)現(xiàn)多文件上傳功能,需要的朋友可以參考下
    2017-07-07
  • 詳解IntelliJ IDEA中TortoiseSVN修改服務(wù)器地址的方法

    詳解IntelliJ IDEA中TortoiseSVN修改服務(wù)器地址的方法

    這篇文章主要介紹了詳解IntelliJ IDEA中TortoiseSVN修改服務(wù)器地址的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-12-12
  • 教你安裝eclipse2021并配置內(nèi)網(wǎng)maven中心倉(cāng)庫(kù)的圖文詳解

    教你安裝eclipse2021并配置內(nèi)網(wǎng)maven中心倉(cāng)庫(kù)的圖文詳解

    本文能通過圖文并茂的形式給大家介紹安裝eclipse2021并配置內(nèi)網(wǎng)maven中心倉(cāng)庫(kù)的相關(guān)知識(shí),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2021-09-09
  • springBoot熱部署、請(qǐng)求轉(zhuǎn)發(fā)與重定向步驟詳解

    springBoot熱部署、請(qǐng)求轉(zhuǎn)發(fā)與重定向步驟詳解

    這篇文章主要介紹了springBoot熱部署、請(qǐng)求轉(zhuǎn)發(fā)與重定向,本文通過示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-06-06
  • Java編寫日歷表的3種方式

    Java編寫日歷表的3種方式

    這篇文章主要為大家詳細(xì)介紹了Java編寫日歷表的3種方式,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • Java?SpringAOP技術(shù)之注解方式詳解

    Java?SpringAOP技術(shù)之注解方式詳解

    這篇文章主要為大家詳細(xì)介紹了Java?SpringAOP技術(shù)之注解方式,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • mybatisplus的坑?insert標(biāo)簽insert?into?select無參數(shù)問題的解決

    mybatisplus的坑?insert標(biāo)簽insert?into?select無參數(shù)問題的解決

    這篇文章主要介紹了mybatisplus的坑?insert標(biāo)簽insert?into?select無參數(shù)問題的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • Java中將接口返回的字節(jié)串轉(zhuǎn)為文件詳解

    Java中將接口返回的字節(jié)串轉(zhuǎn)為文件詳解

    這篇文章主要給大家介紹了關(guān)于Java中將接口返回的字節(jié)串轉(zhuǎn)為文件的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2021-11-11
  • Java中圖像銳化操作的方法詳解

    Java中圖像銳化操作的方法詳解

    這篇文章主要給大家介紹了關(guān)于Java中圖像銳化操作的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11

最新評(píng)論