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

MyBatisPlus的使用最全實(shí)例詳解

 更新時(shí)間:2025年09月20日 14:04:40   作者:Leo_lc—lc  
MyBatis-Plus是MyBatis增強(qiáng)工具,簡(jiǎn)化開(kāi)發(fā)并提升效率,內(nèi)置通用Mapper、Service及條件構(gòu)造器,支持動(dòng)態(tài)SQL、分頁(yè)查詢與注解配置,適用于單表操作,復(fù)雜SQL可手動(dòng)編寫(xiě),減少樣板代碼,優(yōu)化開(kāi)發(fā)體驗(yàn)

一、MyBatis-Plus 是什么?

  • ??定位??:MyBatis 的增強(qiáng)工具,簡(jiǎn)化開(kāi)發(fā),提高效率。
  • ??特點(diǎn)??:內(nèi)置通用 Mapper、通用 Service、條件構(gòu)造器、分頁(yè)插件等,無(wú)需編寫(xiě)繁瑣的 XML。
  • ??核心思想??:通過(guò)少量配置實(shí)現(xiàn)單表 CRUD 操作,復(fù)雜 SQL 仍可手寫(xiě)。

二、快速開(kāi)始(Spring Boot 環(huán)境)

1. 添加依賴

在 pom.xml 中引入:

<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>最新版本(如3.5.3)</version>
</dependency>
<!-- 數(shù)據(jù)庫(kù)驅(qū)動(dòng)(如MySQL) -->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.25</version>
</dependency>

2. 配置數(shù)據(jù)庫(kù)

在 application.yml 中:

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/test?useSSL=false&serverTimezone=UTC
    username: root
    password: root
    driver-class-name: com.mysql.cj.jdbc.Driver

3. 創(chuàng)建實(shí)體類

@Data  // Lombok 注解,自動(dòng)生成 getter/setter
@TableName("user")  // 對(duì)應(yīng)數(shù)據(jù)庫(kù)表名
public class User {
    @TableId(type = IdType.AUTO)  // 主鍵自增
    private Long id;
    private String name;
    private Integer age;
    private String email;
}

4. 創(chuàng)建 Mapper 接口

public interface UserMapper extends BaseMapper<User> {
    // 無(wú)需寫(xiě) XML,直接繼承 BaseMapper 即具備 CRUD 方法
}

5. 在啟動(dòng)類添加注解

@SpringBootApplication
@MapperScan("com.example.mapper")  // 掃描 Mapper 接口所在包
public class Application {
    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}

三、基本 CRUD 操作

1. 插入數(shù)據(jù)

User user = new User();
user.setName("張三");
user.setAge(25);
user.setEmail("zhangsan@example.com");
userMapper.insert(user);  // 插入后自動(dòng)回填主鍵

2. 查詢操作

// 根據(jù) ID 查詢
User user = userMapper.selectById(1L);
// 條件查詢(查詢 name=張三且 age=25 的用戶)
QueryWrapper<User> queryWrapper = new QueryWrapper<>();
queryWrapper.eq("name", "張三").eq("age", 25);
List<User> users = userMapper.selectList(queryWrapper);

3. 更新操作

User user = new User();
user.setId(1L);
user.setAge(30);
userMapper.updateById(user);  // 根據(jù) ID 更新

4. 刪除操作

userMapper.deleteById(1L);  // 根據(jù) ID 刪除
// 條件刪除
QueryWrapper<User> wrapper = new QueryWrapper<>();
wrapper.eq("age", 25);
userMapper.delete(wrapper);

四、條件構(gòu)造器(Wrapper)

1.QueryWrapper詳解

(1)基本用法

QueryWrapper<User> wrapper = new QueryWrapper<>();

(2)常用條件方法

a. 等值條件

wrapper.eq("name", "張三")     // name = '張三'
       .ne("age", 20)         // age != 20
       .isNotNull("email");   // email IS NOT NULL

b. 范圍條件

wrapper.gt("age", 18)        // age > 18
       .ge("age", 20)        // age >= 20
       .lt("age", 30)        // age < 30
       .le("age", 25)        // age <= 25
       .between("age", 20, 30) // age BETWEEN 20 AND 30
       .notBetween("age", 20, 30); // age NOT BETWEEN 20 AND 30

c. 模糊查詢

wrapper.like("name", "張")    // name LIKE '%張%'
       .likeLeft("name", "三")  // name LIKE '%三'
       .likeRight("name", "張") // name LIKE '張%'
       .notLike("name", "李");  // name NOT LIKE '%李%'

d. 邏輯條件

wrapper.and(w -> w.eq("name", "張三").gt("age", 20))  // AND (name = '張三' AND age > 20)
       .or(w -> w.eq("name", "李四").lt("age", 30)); // OR (name = '李四' OR age < 30)

e. 排序與分組

wrapper.orderByAsc("age")     // ORDER BY age ASC
       .orderByDesc("id")    // ORDER BY id DESC
       .groupBy("department"); // GROUP BY department

f. 指定返回字段

wrapper.select("id", "name", "age"); // SELECT id, name, age

g. 子查詢

wrapper.inSql("id", "SELECT id FROM user WHERE age > 18")  // id IN (SELECT id ...)
       .notInSql("id", "SELECT id FROM user WHERE age < 10");

(3)動(dòng)態(tài)條件拼接

根據(jù)業(yè)務(wù)邏輯動(dòng)態(tài)添加條件:

QueryWrapper<User> wrapper = new QueryWrapper<>();
if (StringUtils.isNotBlank(name)) {
    wrapper.like("name", name);
}
if (age != null) {
    wrapper.gt("age", age);
}
List<User> users = userMapper.selectList(wrapper);

2.LambdaQueryWrapper詳解

(1)為什么用Lambda

  • ??優(yōu)勢(shì)??:避免字段名硬編碼,編譯時(shí)檢查,重構(gòu)友好。
  • ??語(yǔ)法??:通過(guò) User::getXxx 引用字段。

(2)基本用法

LambdaQueryWrapper<User> lambdaWrapper = new LambdaQueryWrapper<>();

(3)常用方法

lambdaWrapper.eq(User::getName, "張三")
             .gt(User::getAge, 20)
             .between(User::getAge, 20, 30)
             .like(User::getName, "張")
             .orderByAsc(User::getAge);

 (4)動(dòng)態(tài)條件示例

lambdaWrapper
    .eq(name != null, User::getName, name) // 僅當(dāng) name 不為空時(shí)生效
    .gt(age != null, User::getAge, age);

3.復(fù)雜條件組合

(1)嵌套條件

QueryWrapper<User> wrapper = new QueryWrapper<>();
wrapper.and(w -> w.eq("name", "張三").or().eq("name", "李四"))
       .and(w -> w.gt("age", 20).lt("age", 30));

生成的SQL:

WHERE (name = '張三' OR name = '李四') AND (age > 20 AND age < 30)

 (2)多OR條件

wrapper.or(w -> w.eq("name", "張三").eq("name", "李四"));

生成的SQL:

WHERE name = '張三' OR name = '李四'

4.條件構(gòu)造器的鏈?zhǔn)秸{(diào)用優(yōu)化

(1)直接鏈?zhǔn)教魬?zhàn)

List<User> users = userMapper.selectList(
    new QueryWrapper<User>()
        .eq("name", "張三")
        .gt("age", 20)
        .orderByDesc("id")
);

(2)復(fù)用 Wrapper 對(duì)象

QueryWrapper<User> wrapper = new QueryWrapper<>();
wrapper.eq("status", 1);
// 根據(jù)不同場(chǎng)景追加條件
if (isAdmin) {
    wrapper.eq("is_admin", 1);
} else {
    wrapper.eq("department", "IT");
}

5.條件構(gòu)造器的實(shí)際應(yīng)用場(chǎng)景

(1)動(dòng)態(tài)搜索功能

public List<User> searchUsers(String keyword, Integer minAge, Integer maxAge) {
    LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();
    wrapper.like(StringUtils.isNotBlank(keyword), User::getName, keyword)
           .or()
           .like(StringUtils.isNotBlank(keyword), User::getEmail, keyword)
           .ge(minAge != null, User::getAge, minAge)
           .le(maxAge != null, User::getAge, maxAge);
    return userMapper.selectList(wrapper);
}

(2)多表聯(lián)查中的條件傳遞

// 假設(shè)聯(lián)查用戶表和訂單表
QueryWrapper<User> wrapper = new QueryWrapper<>();
wrapper.inSql("id", "SELECT user_id FROM order WHERE amount > 1000");
List<User> users = userMapper.selectList(wrapper);

6.總結(jié)表格

方法名作用示例
eq() / ne()等于 / 不等于eq("name", "張三")
gt() / lt()大于 / 小于gt("age", 20)
between()范圍查詢between("age", 20, 30)
like() / notLike()模糊查詢like("name", "張")
and() / or()邏輯與 / 或and(w -> w.eq(...))
orderByAsc()升序排序orderByAsc("age")
select()指定返回字段select("id", "name")
inSql()子查詢inSql("id", "SELECT id FROM ...")

五、分頁(yè)查詢

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

@Configuration
public class MyBatisPlusConfig {
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        interceptor.addInnerInterceptor(new PaginationInnerInterceptor());
        return interceptor;
    }
}

2. 使用分頁(yè)

// 第 2 頁(yè),每頁(yè) 5 條
Page<User> page = new Page<>(2, 5);
QueryWrapper<User> wrapper = new QueryWrapper<>();
wrapper.gt("age", 20);
Page<User> result = userMapper.selectPage(page, wrapper);
// 獲取結(jié)果
List<User> users = result.getRecords();
long total = result.getTotal();

六、常用注解

1.@TableName

  • 指定實(shí)體類對(duì)應(yīng)的表名。
  • 示例:@TableName("sys_user")

2.@TableId

  • 標(biāo)記主鍵字段。
  • 可選主鍵策略:
    • IdType.AUTO:數(shù)據(jù)庫(kù)自增
    • IdType.ASSIGN_ID:雪花算法生成 ID(默認(rèn))

3.@TableField

  • 解決字段名與數(shù)據(jù)庫(kù)列名不一致問(wèn)題。
  • 示例:@TableField("nick_name")

七、總結(jié)

  • ??優(yōu)點(diǎn)??:減少樣板代碼,提高開(kāi)發(fā)效率。
  • ??適用場(chǎng)景??:?jiǎn)伪聿僮鳌⒑?jiǎn)單查詢。
  • ??復(fù)雜 SQL??:仍可通過(guò) XML 或注解方式編寫(xiě)。

到此這篇關(guān)于MyBatisPlus的使用的文章就介紹到這了,更多相關(guān)MyBatisPlus使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java8?Stream流根據(jù)多個(gè)字段去重

    Java8?Stream流根據(jù)多個(gè)字段去重

    這篇文章主要介紹了Java8?Stream流根據(jù)多個(gè)字段去重,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • 關(guān)于MapStruct的使用教程

    關(guān)于MapStruct的使用教程

    MapStruct 是一個(gè)用于 Java Bean 映射的代碼生成器,通過(guò)注解處理器自動(dòng)生成映射代碼,以下是 MapStruct 的基本使用方法:添加依賴、定義映射接口、使用映射方法、定義自定義映射方法、處理復(fù)雜映射、集成 Spring 等
    2025-02-02
  • Linux將Spring Boot項(xiàng)目的Jar包注冊(cè)為開(kāi)機(jī)自啟動(dòng)系統(tǒng)服務(wù)的操作方法

    Linux將Spring Boot項(xiàng)目的Jar包注冊(cè)為開(kāi)機(jī)自啟動(dòng)系統(tǒng)服務(wù)的操作方法

    jar文件是從maven package打包出來(lái)的,config/application.yml是原先在項(xiàng)目的resources文件夾里,外置出來(lái)方便適配開(kāi)發(fā)環(huán)境和正式環(huán)境,這篇文章主要介紹了Linux將Spring Boot項(xiàng)目的Jar包注冊(cè)為開(kāi)機(jī)自啟動(dòng)系統(tǒng)服務(wù)的操作方法,需要的朋友可以參考下
    2023-10-10
  • Java中l(wèi)og4j注解詳解與實(shí)戰(zhàn)指南(附具體示例)

    Java中l(wèi)og4j注解詳解與實(shí)戰(zhàn)指南(附具體示例)

    日志是軟件開(kāi)發(fā)中不可或缺的一部分,它能夠幫助開(kāi)發(fā)者追蹤程序的運(yùn)行狀態(tài),診斷問(wèn)題,以及監(jiān)控系統(tǒng)性能,這篇文章主要介紹了Java中l(wèi)og4j注解詳解與實(shí)戰(zhàn)的相關(guān)資料,需要的朋友可以參考下
    2025-07-07
  • JavaWeb中使用JavaMail實(shí)現(xiàn)發(fā)送郵件功能實(shí)例詳解

    JavaWeb中使用JavaMail實(shí)現(xiàn)發(fā)送郵件功能實(shí)例詳解

    這篇文章主要介紹了JavaWeb中使用JavaMail實(shí)現(xiàn)發(fā)送郵件功能的實(shí)例代碼,非常不錯(cuò)具有參考借鑒價(jià)值,感興趣的朋友一起看看吧
    2016-05-05
  • java swing實(shí)現(xiàn)電影購(gòu)票系統(tǒng)

    java swing實(shí)現(xiàn)電影購(gòu)票系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了java swing實(shí)現(xiàn)電影購(gòu)票系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • Java Array.sort()源碼分析講解

    Java Array.sort()源碼分析講解

    Arrays類中有一個(gè)sort()方法,該方法是Arrays類的靜態(tài)方法,在需要對(duì)數(shù)組進(jìn)行排序時(shí),非常的好用。但是sort()的參數(shù)有好幾種,下面我就為大家一一介紹,這幾種形式的用法
    2022-08-08
  • Java Mybatis一級(jí)緩存和二級(jí)緩存

    Java Mybatis一級(jí)緩存和二級(jí)緩存

    緩存是內(nèi)存當(dāng)中一塊存儲(chǔ)數(shù)據(jù)的區(qū)域,目的是提高查詢效率,降低服務(wù)器和數(shù)據(jù)庫(kù)的壓力,這篇文章主要介紹了Mybatis一級(jí)緩存和二級(jí)緩存,感興趣的同學(xué)可以參考閱讀本文
    2023-04-04
  • Java Map.Entry的使用方法解析

    Java Map.Entry的使用方法解析

    這篇文章主要介紹了Java Map.Entry的使用方法解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03
  • 詳解Java中的do...while循環(huán)語(yǔ)句的使用方法

    詳解Java中的do...while循環(huán)語(yǔ)句的使用方法

    這篇文章主要介紹了Java中的do...while循環(huán)語(yǔ)句的使用方法,是Java入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-10-10

最新評(píng)論