Spring Boot 中整合 MyBatis-Plus詳細(xì)步驟(最新推薦)
在 Spring Boot 中整合 MyBatis-Plus 可以按照以下步驟進(jìn)行:
一、整合步驟
1. 創(chuàng)建 Spring Boot 項(xiàng)目
首先,使用 Spring Initializr(https://start.spring.io/)創(chuàng)建一個(gè)新的 Spring Boot 項(xiàng)目。在創(chuàng)建過(guò)程中,選擇以下依賴(lài):
- Spring Web
- MySQL Driver
- MyBatis-Plus
2. 配置項(xiàng)目依賴(lài)
如果手動(dòng)創(chuàng)建 pom.xml 文件,確保添加以下依賴(lài):
<dependencies>
<!-- Spring Boot Starter Web -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- MyBatis-Plus Starter -->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>最新版本</version>
</dependency>
<!-- MySQL Driver -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<!-- Spring Boot Starter Test -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>請(qǐng)將 最新版本 替換為 MyBatis-Plus 的實(shí)際最新版本號(hào)。
3. 配置數(shù)據(jù)源
在 application.yml 文件中配置數(shù)據(jù)庫(kù)連接信息:
spring:
datasource:
url: jdbc:mysql://localhost:3306/yourdatabase
username: yourusername
password: yourpassword
driver-class-name: com.mysql.cj.jdbc.Driver將 yourdatabase、yourusername 和 yourpassword 替換為實(shí)際的數(shù)據(jù)庫(kù)名稱(chēng)、用戶(hù)名和密碼。
4. 創(chuàng)建實(shí)體類(lèi)
創(chuàng)建一個(gè) Java 實(shí)體類(lèi),用于映射數(shù)據(jù)庫(kù)表。例如,創(chuàng)建一個(gè) User 實(shí)體類(lèi):
package com.example.demo.entity;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.Data;
@Data
@TableName("user")
public class User {
private Long id;
private String username;
private String password;
}@Data 是 Lombok 注解,用于自動(dòng)生成 getter、setter、equals、hashCode 和 toString 方法。@TableName 注解指定實(shí)體類(lèi)對(duì)應(yīng)的數(shù)據(jù)庫(kù)表名。
5. 創(chuàng)建 Mapper 接口
創(chuàng)建一個(gè) Mapper 接口,繼承 BaseMapper 接口,BaseMapper 是 MyBatis-Plus 提供的基礎(chǔ)接口,包含了常用的 CRUD 方法。例如,創(chuàng)建一個(gè) UserMapper 接口:
package com.example.demo.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.example.demo.entity.User;
import org.apache.ibatis.annotations.Mapper;
@Mapper
public interface UserMapper extends BaseMapper<User> {
// 可以在這里定義自定義的 SQL 方法
}@Mapper 注解用于將該接口標(biāo)記為 MyBatis 的 Mapper 接口。
6. 創(chuàng)建 Service 層
創(chuàng)建一個(gè) Service 接口和其實(shí)現(xiàn)類(lèi)。例如,創(chuàng)建一個(gè) UserService 接口和 UserServiceImpl 實(shí)現(xiàn)類(lèi):
package com.example.demo.service;
import com.example.demo.entity.User;
import com.baomidou.mybatisplus.extension.service.IService;
import java.util.List;
public interface UserService extends IService<User> {
// 可以在這里定義自定義的業(yè)務(wù)方法
}package com.example.demo.service.impl;
import com.example.demo.entity.User;
import com.example.demo.mapper.UserMapper;
import com.example.demo.service.UserService;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import org.springframework.stereotype.Service;
import java.util.List;
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
// 如果需要,可以重寫(xiě)或?qū)崿F(xiàn)自定義方法
}ServiceImpl 是 MyBatis-Plus 提供的基礎(chǔ) Service 實(shí)現(xiàn)類(lèi),它提供了基本的 CRUD 方法實(shí)現(xiàn)。
7. 創(chuàng)建 Controller 層
創(chuàng)建一個(gè) Controller 層,用于處理客戶(hù)端請(qǐng)求。例如,創(chuàng)建一個(gè) UserController:
package com.example.demo.controller;
import com.example.demo.entity.User;
import com.example.demo.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import java.util.List;
@RestController
@RequestMapping("/users")
public class UserController {
@Autowired
private UserService userService;
@GetMapping
public List<User> findAll() {
return userService.list();
}
@GetMapping("/{id}")
public User findById(@PathVariable Long id) {
return userService.getById(id);
}
@PostMapping
public boolean save(@RequestBody User user) {
return userService.save(user);
}
@PutMapping
public boolean update(@RequestBody User user) {
return userService.updateById(user);
}
@DeleteMapping("/{id}")
public boolean delete(@PathVariable Long id) {
return userService.removeById(id);
}
}8. 配置 MyBatis-Plus 掃描
在 Spring Boot 主應(yīng)用類(lèi)上添加 @MapperScan 注解,掃描 Mapper 接口所在的包:
package com.example.demo;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
@MapperScan("com.example.demo.mapper")
public class DemoApplication {
public static void main(String[] args) {
SpringApplication.run(DemoApplication.class, args);
}
}9. 測(cè)試
可以使用 Spring Boot 的測(cè)試框架來(lái)測(cè)試各個(gè)接口:
package com.example.demo;
import com.example.demo.entity.User;
import com.example.demo.service.UserService;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import static org.junit.jupiter.api.Assertions.*;
@SpringBootTest
public class DemoApplicationTests {
@Autowired
private UserService userService;
@Test
public void testFindAll() {
assertTrue(userService.list().size() >= 0);
}
@Test
public void testFindById() {
User user = new User();
user.setUsername("testuser");
user.setPassword("testpassword");
userService.save(user);
assertNotNull(userService.getById(user.getId()));
}
@Test
public void testSave() {
User user = new User();
user.setUsername("newuser");
user.setPassword("newpassword");
assertTrue(userService.save(user));
}
@Test
public void testUpdate() {
User user = new User();
user.setUsername("updateuser");
user.setPassword("updatepassword");
userService.save(user);
user.setPassword("newupdatepassword");
assertTrue(userService.updateById(user));
}
@Test
public void testDelete() {
User user = new User();
user.setUsername("deleteuser");
user.setPassword("deletepassword");
userService.save(user);
assertTrue(userService.removeById(user.getId()));
}
}通過(guò)以上步驟,你就可以在 Spring Boot 項(xiàng)目中成功整合 MyBatis-Plus,并實(shí)現(xiàn)基本的 CRUD 操作。在實(shí)際項(xiàng)目中,你可以根據(jù)需求進(jìn)一步擴(kuò)展和優(yōu)化代碼。
二、 基本 CRUD 操作
在前面整合的基礎(chǔ)上,我們已經(jīng)有了基本的 CRUD 方法。
新增操作
在 UserService 中調(diào)用 save 方法:
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
// 新增操作
@Override
public boolean saveUser(User user) {
return this.save(user);
}
}查詢(xún)操作
根據(jù) ID 查詢(xún):調(diào)用 getById 方法。
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
// 根據(jù) ID 查詢(xún)
@Override
public User getUserById(Long id) {
return this.getById(id);
}
}查詢(xún)所有:調(diào)用 list 方法。
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
// 查詢(xún)所有
@Override
public List<User> getAllUsers() {
return this.list();
}
}更新操作
調(diào)用 updateById 方法:
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
// 更新操作
@Override
public boolean updateUser(User user) {
return this.updateById(user);
}
}刪除操作
根據(jù) ID 刪除:調(diào)用 removeById 方法。
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
// 根據(jù) ID 刪除
@Override
public boolean deleteUserById(Long id) {
return this.removeById(id);
}
}條件查詢(xún)
使用 QueryWrapper 構(gòu)建查詢(xún)條件。
簡(jiǎn)單條件查詢(xún)
例如,查詢(xún)用戶(hù)名等于某個(gè)值的用戶(hù):
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
@Override
public List<User> findUsersByUsername(String username) {
QueryWrapper<User> queryWrapper = new QueryWrapper<>();
queryWrapper.eq("username", username);
return this.list(queryWrapper);
}
}復(fù)雜條件查詢(xún)
多個(gè)條件組合,例如查詢(xún)用戶(hù)名包含某個(gè)字符串且年齡大于某個(gè)值的用戶(hù):
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
@Override
public List<User> findComplexUsers(String usernameLike, Integer ageGreaterThan) {
QueryWrapper<User> queryWrapper = new QueryWrapper<>();
queryWrapper.like("username", usernameLike);
queryWrapper.gt("age", ageGreaterThan);
return this.list(queryWrapper);
}
}分頁(yè)查詢(xún)
使用 Page 類(lèi)實(shí)現(xiàn)分頁(yè)查詢(xún)。
首先,在 UserService 中定義分頁(yè)查詢(xún)方法:
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
@Override
public Page<User> getUserPage(int current, int size) {
Page<User> page = new Page<>(current, size);
return this.page(page);
}
}批量操作
批量插入
使用 saveBatch 方法批量插入用戶(hù):
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
@Override
public boolean saveUserBatch(List<User> userList) {
return this.saveBatch(userList);
}
}批量更新
使用 updateBatchById 方法批量更新用戶(hù):
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
@Override
public boolean updateUserBatch(List<User> userList) {
return this.updateBatchById(userList);
}
}批量刪除
使用 removeByIds 方法批量刪除用戶(hù):
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
@Override
public boolean deleteUserBatch(List<Long> idList) {
return this.removeByIds(idList);
}
}自定義 SQL 操作
如果 MyBatis-Plus 提供的內(nèi)置方法無(wú)法滿(mǎn)足需求,可以在 Mapper 接口中定義自定義 SQL 方法。
在 Mapper 接口中定義方法
@Mapper
public interface UserMapper extends BaseMapper<User> {
@Select("SELECT * FROM user WHERE age > #{age}")
List<User> findUsersByAge(int age);
}在 Service 層調(diào)用自定義方法
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
@Override
public List<User> findUsersByAge(int age) {
return userMapper.findUsersByAge(age);
}
}示例代碼總結(jié)
上述示例展示了在 Spring Boot 中使用 MyBatis-Plus 進(jìn)行各種數(shù)據(jù)庫(kù)操作的方法。在實(shí)際項(xiàng)目中,可以根據(jù)具體需求,在 Service 層和 Mapper 層靈活組合和擴(kuò)展這些方法,以實(shí)現(xiàn)復(fù)雜的業(yè)務(wù)邏輯。
注意事項(xiàng)
- 確保數(shù)據(jù)庫(kù)表結(jié)構(gòu)與實(shí)體類(lèi)屬性對(duì)應(yīng),否則可能導(dǎo)致數(shù)據(jù)操作異常。
- 在使用
QueryWrapper構(gòu)建條件時(shí),注意條件的正確性和安全性,防止 SQL 注入。 - 對(duì)于分頁(yè)操作,要合理設(shè)置分頁(yè)參數(shù),避免數(shù)據(jù)量過(guò)大導(dǎo)致性能問(wèn)題。
通過(guò)以上內(nèi)容,你可以全面掌握在 Spring Boot 中使用 MyBatis-Plus 進(jìn)行數(shù)據(jù)庫(kù)操作的方法。
到此這篇關(guān)于Spring Boot 中整合 MyBatis-Plus詳細(xì)步驟的文章就介紹到這了,更多相關(guān)Spring Boot 整合 MyBatis-Plus內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 5分鐘快速搭建SpringBoot3?+?MyBatis-Plus工程/項(xiàng)目的實(shí)現(xiàn)示例
- 解決mybatis-plus-boot-starter與mybatis-spring-boot-starter的錯(cuò)誤問(wèn)題
- Spring?Boot?集成?MyBatis?全面講解(最新推薦)
- Spring Boot 中使用 Mybatis Plus的操作方法
- SpringBoot同時(shí)集成Mybatis和Mybatis-plus框架
- Springboot使用MybatisPlus實(shí)現(xiàn)mysql樂(lè)觀鎖
- 淺談Spring Boot、MyBatis、MyBatis-Plus 依賴(lài)版本對(duì)應(yīng)關(guān)系
- Spring Boot Mybatis++ 2025詳解
相關(guān)文章
Java中BigDecimal的equals方法和compareTo方法的區(qū)別詳析
這篇文章主要給大家介紹了關(guān)于Java中BigDecimal的equals方法和compareTo方法區(qū)別的相關(guān)資料,對(duì)于BigDecimal的大小比較,用equals方法的話(huà)會(huì)不僅會(huì)比較值的大小,還會(huì)比較兩個(gè)對(duì)象的精確度,而compareTo方法則不會(huì)比較精確度,只比較數(shù)值的大小,需要的朋友可以參考下2023-11-11
Springboot集成graylog及配置過(guò)程解析
這篇文章主要介紹了Springboot集成graylog及配置過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-12-12
Java中LocalCache本地緩存實(shí)現(xiàn)代碼
本篇文章主要介紹了Java中LocalCache本地緩存實(shí)現(xiàn)代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-05-05
SpringBoot如何讀取xml配置bean(@ImportResource)
這篇文章主要介紹了SpringBoot如何讀取xml配置bean(@ImportResource),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01
mybatis新增save結(jié)束后自動(dòng)返回主鍵id詳解
這篇文章主要介紹了mybatis新增save結(jié)束后自動(dòng)返回主鍵id詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12
Security中的@PostAuthorize、@PreFilter和@PostFilter詳解
這篇文章主要介紹了Security中的@PostAuthorize、@PreFilter和@PostFilter詳解,@PostAuthorize是在方法調(diào)用完成后進(jìn)行權(quán)限檢查,它不能控制方法是否能被調(diào)用,只能在方法調(diào)用完成后檢查權(quán)限決定是否要拋出AccessDeniedException,需要的朋友可以參考下2023-11-11

