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)建過程中,選擇以下依賴:
- Spring Web
- MySQL Driver
- MyBatis-Plus
2. 配置項(xiàng)目依賴
如果手動(dòng)創(chuàng)建 pom.xml
文件,確保添加以下依賴:
<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>
請將 最新版本
替換為 MyBatis-Plus 的實(shí)際最新版本號(hào)。
3. 配置數(shù)據(jù)源
在 application.yml
文件中配置數(shù)據(jù)庫連接信息:
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ù)庫名稱、用戶名和密碼。
4. 創(chuàng)建實(shí)體類
創(chuàng)建一個(gè) Java 實(shí)體類,用于映射數(shù)據(jù)庫表。例如,創(chuàng)建一個(gè) User
實(shí)體類:
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í)體類對(duì)應(yīng)的數(shù)據(jù)庫表名。
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)類。例如,創(chuàng)建一個(gè) UserService
接口和 UserServiceImpl
實(shí)現(xiàn)類:
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 { // 如果需要,可以重寫或?qū)崿F(xiàn)自定義方法 }
ServiceImpl
是 MyBatis-Plus 提供的基礎(chǔ) Service 實(shí)現(xiàn)類,它提供了基本的 CRUD 方法實(shí)現(xiàn)。
7. 創(chuàng)建 Controller 層
創(chuàng)建一個(gè) Controller 層,用于處理客戶端請求。例如,創(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)用類上添加 @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. 測試
可以使用 Spring Boot 的測試框架來測試各個(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())); } }
通過以上步驟,你就可以在 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); } }
查詢操作
根據(jù) ID 查詢:調(diào)用 getById
方法。
@Service public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService { // 根據(jù) ID 查詢 @Override public User getUserById(Long id) { return this.getById(id); } }
查詢所有:調(diào)用 list
方法。
@Service public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService { // 查詢所有 @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); } }
條件查詢
使用 QueryWrapper
構(gòu)建查詢條件。
簡單條件查詢
例如,查詢用戶名等于某個(gè)值的用戶:
@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ù)雜條件查詢
多個(gè)條件組合,例如查詢用戶名包含某個(gè)字符串且年齡大于某個(gè)值的用戶:
@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); } }
分頁查詢
使用 Page
類實(shí)現(xiàn)分頁查詢。
首先,在 UserService
中定義分頁查詢方法:
@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
方法批量插入用戶:
@Service public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService { @Override public boolean saveUserBatch(List<User> userList) { return this.saveBatch(userList); } }
批量更新
使用 updateBatchById
方法批量更新用戶:
@Service public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService { @Override public boolean updateUserBatch(List<User> userList) { return this.updateBatchById(userList); } }
批量刪除
使用 removeByIds
方法批量刪除用戶:
@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)置方法無法滿足需求,可以在 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ù)庫操作的方法。在實(shí)際項(xiàng)目中,可以根據(jù)具體需求,在 Service 層和 Mapper 層靈活組合和擴(kuò)展這些方法,以實(shí)現(xiàn)復(fù)雜的業(yè)務(wù)邏輯。
注意事項(xiàng)
- 確保數(shù)據(jù)庫表結(jié)構(gòu)與實(shí)體類屬性對(duì)應(yīng),否則可能導(dǎo)致數(shù)據(jù)操作異常。
- 在使用
QueryWrapper
構(gòu)建條件時(shí),注意條件的正確性和安全性,防止 SQL 注入。 - 對(duì)于分頁操作,要合理設(shè)置分頁參數(shù),避免數(shù)據(jù)量過大導(dǎo)致性能問題。
通過以上內(nèi)容,你可以全面掌握在 Spring Boot 中使用 MyBatis-Plus 進(jìn)行數(shù)據(jù)庫操作的方法。
到此這篇關(guān)于Spring Boot 中整合 MyBatis-Plus詳細(xì)步驟的文章就介紹到這了,更多相關(guān)Spring Boot 整合 MyBatis-Plus內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 5分鐘快速搭建SpringBoot3?+?MyBatis-Plus工程/項(xiàng)目的實(shí)現(xiàn)示例
- 解決mybatis-plus-boot-starter與mybatis-spring-boot-starter的錯(cuò)誤問題
- Spring?Boot?集成?MyBatis?全面講解(最新推薦)
- Spring Boot 中使用 Mybatis Plus的操作方法
- SpringBoot同時(shí)集成Mybatis和Mybatis-plus框架
- Springboot使用MybatisPlus實(shí)現(xiàn)mysql樂觀鎖
- 淺談Spring Boot、MyBatis、MyBatis-Plus 依賴版本對(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ì)比較兩個(gè)對(duì)象的精確度,而compareTo方法則不會(huì)比較精確度,只比較數(shù)值的大小,需要的朋友可以參考下2023-11-11Java中LocalCache本地緩存實(shí)現(xiàn)代碼
本篇文章主要介紹了Java中LocalCache本地緩存實(shí)現(xiàn)代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-05-05SpringBoot如何讀取xml配置bean(@ImportResource)
這篇文章主要介紹了SpringBoot如何讀取xml配置bean(@ImportResource),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01mybatis新增save結(jié)束后自動(dòng)返回主鍵id詳解
這篇文章主要介紹了mybatis新增save結(jié)束后自動(dòng)返回主鍵id詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12Security中的@PostAuthorize、@PreFilter和@PostFilter詳解
這篇文章主要介紹了Security中的@PostAuthorize、@PreFilter和@PostFilter詳解,@PostAuthorize是在方法調(diào)用完成后進(jìn)行權(quán)限檢查,它不能控制方法是否能被調(diào)用,只能在方法調(diào)用完成后檢查權(quán)限決定是否要拋出AccessDeniedException,需要的朋友可以參考下2023-11-11