MyBatisPlus的使用最全實(shí)例詳解
一、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.Driver3. 創(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 NULLb. 范圍條件
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 30c. 模糊查詢
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 departmentf. 指定返回字段
wrapper.select("id", "name", "age"); // SELECT id, name, ageg. 子查詢
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)文章
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)指南(附具體示例)
日志是軟件開(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í)例代碼,非常不錯(cuò)具有參考借鑒價(jià)值,感興趣的朋友一起看看吧2016-05-05
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中的do...while循環(huán)語(yǔ)句的使用方法
這篇文章主要介紹了Java中的do...while循環(huán)語(yǔ)句的使用方法,是Java入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-10-10

