MyBatis-Plus 通用 Service

引言

在開發 Java Web 應用程序時,我們經常需要進行大量的數據庫操作,如創建、讀取、更新和刪除(CRUD)。MyBatis-Plus 作為一個強大的 MyBatis 增強工具,為我們提供了通用 Service 接口,極大地簡化了這些操作。本文將詳細介紹 MyBatis-Plus 通用 Service 的使用,結合具體代碼示例,幫助大家更好地理解和應用。

1. 通用 Service 概述

MyBatis-Plus 的通用 Service CRUD 封裝了IService接口,通過采用get查詢單行、remove刪除、list查詢集合、page分頁等前綴命名方式,進一步封裝了 CRUD 操作,避免了 Mapper 層的混淆。同時,泛型T可以是任意實體對象,使得該接口具有很高的通用性。

如果我們在項目中可能存在自定義通用 Service 方法的需求,建議創建自己的IBaseService繼承 MyBatis-Plus 提供的基類。官方文檔地址為:[https://baomidou.com/pages/49cc81/#service-crud-接口](https://baomidou.com/pages/49cc81/#service-crud-%E6%8E%A5%E5%8F%?A3)

2. 項目環境搭建

在開始之前,我們需要確保項目中已經引入了 MyBatis-Plus 的依賴。以 Maven 為例,在pom.xml中添加以下依賴:

<dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>最新版本號</version>
</dependency>

?

3. 代碼示例

3.1 定義實體類

首先,我們需要定義一個實體類User,用于表示數據庫中的用戶表。

package com.qcby.entity;import com.baomidou.mybatisplus.annotation.TableName;
import lombok.Data;@Data
@TableName("user")
public class User {private Long id;private String name;private Integer age;private String email;
}

?

?

3.2 定義 Service 接口

接下來,我們定義一個UserService接口,繼承自IService<User>

?

package com.qcby.service;import com.baomidou.mybatisplus.extension.service.IService;
import com.qcby.entity.User;public interface UserService extends IService<User> {
}

3.3 實現 Service 接口

然后,我們實現UserService接口。

package com.qcby.service.impl;import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.qcby.entity.User;
import com.qcby.mapper.UserMapper;
import com.qcby.service.UserService;
import org.springframework.stereotype.Service;@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
}

?

3.4 測試 Service 方法

為了驗證通用 Service 的功能,我們編寫一些測試用例。

package com.qcby;import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.qcby.entity.User;
import com.qcby.service.UserService;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;@SpringBootTest
public class MybatisPlusServiceTest {@Autowiredprivate UserService userService;/*** 保存單個用戶*/@Testpublic void savetest(){User user = new User();user.setName("xiaoming");userService.save(user);System.out.println(user.getId());}/*** 批量保存用戶*/@Testpublic void saveBatchTest(){List<User> userList = new ArrayList<>();User user1 = new User();user1.setName("xiaobai");userList.add(user1);User user2 = new User();user2.setName("xiaoli");userList.add(user2);userService.saveBatch(userList);System.out.println(userList.size());}/*** 根據ID刪除用戶*/@Testpublic void removeById(){userService.removeById(1949020695920902146L);}/*** 根據條件刪除用戶*/@Testpublic void remove(){QueryWrapper<User> queryWrapper = new QueryWrapper<>();queryWrapper.gt("id",6l);userService.remove(queryWrapper);}/*** 根據ID更新用戶信息*/@Testpublic void updateById(){User user = new User();user.setId(1949019913414877186l);user.setName("xiaoming");user.setEmail("xiongda@qcby.com");user.setAge(18);userService.updateById(user);}/*** 根據ID查詢用戶信息*/@Testpublic void getById(){userService.getById(1949020696017371138L);}/*** 查詢用戶列表*/@Testpublic void list(){QueryWrapper<User> queryWrapper = new QueryWrapper<>();queryWrapper.gt("id",5l);List<User> list = userService.list(queryWrapper);System.out.println(list);}/*** 分頁查詢用戶信息*/@Testpublic void pageNavigation() {// 創建分頁對象,查詢第1頁,每頁5條Page<User> page = new Page<>(1, 5);// 執行分頁查詢Page<User> resultPage = userService.page(page);// 打印分頁信息System.out.println("當前頁: " + resultPage.getCurrent());System.out.println("每頁大小: " + resultPage.getSize());System.out.println("總記錄數: " + resultPage.getTotal());System.out.println("總頁數: " + resultPage.getPages());System.out.println("當前頁數據: " + resultPage.getRecords());int i = 2;while(resultPage.hasNext()){System.out.println("\n=== 查詢下一頁 ===");page.setCurrent(i); // 設置為第i頁Page<User> nextPage = userService.page(page);System.out.println("當前頁: " + nextPage.getCurrent());System.out.println("當前頁數據: " + nextPage.getRecords());i++;}}
}

4. 代碼解釋

4.1 保存操作

  • save方法用于保存單個實體對象。
  • saveBatch方法用于批量保存實體對象。

4.2 刪除操作

  • removeById方法根據 ID 刪除實體對象。
  • remove方法根據條件刪除實體對象。

4.3 更新操作

  • updateById方法根據 ID 更新實體對象的信息。

4.4 查詢操作

  • getById方法根據 ID 查詢單個實體對象。
  • list方法根據條件查詢實體對象列表。
  • page方法用于分頁查詢實體對象。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/916316.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/916316.shtml
英文地址,請注明出處:http://en.pswp.cn/news/916316.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

聚類-一種無監督分類算法

目錄 1、聚類任務 2、性能度量 &#xff08;1&#xff09;外部指標 &#xff08;2&#xff09;內部指標 3、具體聚類方法 &#xff08;1&#xff09;原型聚類 &#xff08;2&#xff09;密度聚類 &#xff08;3&#xff09;層次聚類 “無監督學習”(unsupervised learnin…

ES6 標簽模板:前端框架的靈活利器

ES6&#xff08;ECMAScript 2015&#xff09;引入的模板字符串&#xff08;Template Literals&#xff09;為 JavaScript 開發者提供了更簡潔的字符串處理方式&#xff0c;而模板字符串標簽&#xff08;Tagged Template Literals&#xff09;則進一步擴展了其功能性。通過標簽函…

解鎖編程核心能力:深入淺出數據結構和算法

——為什么它們是你代碼效率的終極武器&#xff1f; &#x1f31f; 引言&#xff1a;程序世界的基石 想象你正在建造摩天大樓&#xff1a;數據結構是鋼筋骨架&#xff0c;決定建筑的結構與承重能力&#xff1b;算法則是施工藍圖&#xff0c;指導如何高效完成建造。兩者結合&am…

Jenkins運行pytest時指令失效的原因以及解決辦法

錯誤收集 Started by user 偷走晚霞的人 Running as SYSTEM Building in workspace C:\Users\Administrator\.jenkins\workspace\TestAAA [TestAAA] $ cmd /c call C:\Users\Administrator\AppData\Local\Temp\jenkins5821160869728612887.bat C:\Users\Administrator\.jenkins…

MySQL數據庫本地遷移到云端完整教程

一、準備工作 安裝MySQL客戶端工具獲取云端數據庫連接信息&#xff1a; 主機地址端口號用戶名密碼數據庫名二、本地數據庫導出 mysqldump -h 127.0.0.1 -P 4406 -u root -p 數據庫名 > backup.sql執行后會提示輸入密碼&#xff0c;完成后會在當前目錄生成backup.sql文件 三、…

InvokeRepeating避免嵌套調用

InvokeRepeating嵌套這會導致指數級增長的重復調用堆疊。使用單一協程PeriodicActionRoutine替代所有InvokeRepeating避免方法間相互調用造成的堆疊如果需要多層級時間控制&#xff08;如主循環子循環&#xff09;&#xff1a;IEnumerator MultiLevelTimer() {float mainInterv…

【工具】好用的瀏覽器AI助手

&#x1f9e8; 一、什么是 Sider&#xff1f; Sider 是一個 Chrome 瀏覽器插件&#xff0c;你可以把它看作一個「網頁邊上的 AI 小助手」。 &#x1f5e3;? 它就像你網頁旁邊的 AI 機器人&#xff0c;可以幫你回答問題、總結文章、翻譯、寫文案、改寫內容、甚至幫你學習英文&…

C++:list(2)list的模擬實現

list的模擬實現一.list與vector1.底層結構的本質區別2.模擬實現的核心差異2.1數據存儲的方式2.2 初始化的過程2.3 插入元素的操作2.4 刪除元素的操作2.5 訪問元素的效率3.總結二.頭文件list.h1. **命名空間與模板**2. **核心數據結構**3. **構造函數**4. **模板參數設計**5. **…

【595驅動8*8點陣】2022-9-11

緣由LED點陣屏只能一次亮一列-嵌入式-CSDN問答 #include "REG52.h" sbit dsP1^0;//數據線 595的14腳 sbit shP1^1;//數據輸入時鐘線 595的11腳 sbit stP1^2;//輸出存儲器鎖存時鐘線 595的12腳 void QuDong595(unsigned char sj) {unsigned char aa8;while(aa--){ds…

AI總結視頻以及谷歌瀏覽器插件安裝步驟

本篇介紹用AI一鍵總結全網視頻內容的獨家方法&#xff0c;支持B站、抖音、小紅書等任何平臺的視頻&#xff0c;提高學習效率&#xff0c;幫助一鍵提取視頻文案、劃分章節&#xff0c;還能生成雙語翻譯&#xff0c;這個方法直接在線總結所有視頻。 一.準備工作&#xff1a; 需要…

網絡協議HTTP、TCP

概述如何讓數據具有自我描述性?為什么網絡有層級的劃分?交換機、路由器要不要閱讀一個信息的頭部&#xff1f;要不要閱讀數據部分&#xff1f; 網卡&#xff1a;網卡可以完成幀的封裝和解封裝&#xff0c;工作在數據鏈路層。 中繼器&#xff1a;中繼器以比特方式將網絡信號進…

Linux選擇題

第12題&#xff08;多選題&#xff09;原題: 能夠為邏輯卷增加容量的命令有( )。A. lvresize: 此命令可以用來調整邏輯卷的大小&#xff0c;既可以增大也可以縮小。例如&#xff0c;lvresize -L 1G /dev/vgname/lvname 會增加1GB&#xff0c;lvresize -L 10G /dev/vgname/lvnam…

使用釘釘開源api發送釘釘工作消息

在工作管理系統場景中&#xff0c;上下級和不同部門之間常常有請假&#xff0c;餐補等流程操作&#xff0c;而這些操作通常需要人員手動進行&#xff0c;這里我們引入一個釘釘的api&#xff0c;可以基于釘釘來發送工作消息通知1、導入釘釘sdk<dependency><groupId>…

拒絕SQL恐懼:用Python+pyqt打造任意Excel數據庫查詢系統

一、引言 在數字化轉型浪潮中&#xff0c;超過76%的基層業務人員仍被困在"SQL恐懼癥"的泥潭里——他們精通業務邏輯卻受限于技術門檻&#xff0c;面對海量數據時只能反復請求IT部門協助。本項目通過PythonPyQt來構建基于Excel風格的查詢系統&#xff0c;從而打破這種…

KubeKey安裝KubeSphere、部署應用實踐問題總結

使用KubeSphere的KubeKey 安裝K8s 集群過程中&#xff0c;碰到了一些問題&#xff0c;現在都一一解決了&#xff0c;以此記錄一下。 kubekey 安裝k8s 集群報錯 execute task timeout, Timeout1m error: Pipeline[CreateClusterPipeline] execute failed: Module[GreetingsModul…

基于粒子群優化的PID控制在藥液流量控制系統中的應用

基于粒子群優化的PID控制在藥液流量控制系統中的應用 前些天發現了一個巨牛的人工智能學習網站,通俗易懂,風趣幽默,忍不住分享一下給大家,覺得好請收藏。點擊跳轉到網站。 1. 引言 在現代工業控制系統中,精確的流量控制是許多生產過程的關鍵環節。本文針對藥液流量控制…

不用電腦要不要關機?

1. 短時間不用&#xff08;午休、臨時外出&#xff09;&#xff1a;建議「睡眠」或「休眠」睡眠&#xff1a;電腦暫停工作&#xff0c;喚醒速度快&#xff0c;耗電較少適合需要快速恢復工作的場景休眠&#xff1a;整機斷電&#xff0c;喚醒速度比睡眠慢&#xff0c;但完全不耗電…

【Spring AI】SiliconFlow-硅基流動

硅基流動 https://docs.siliconflow.cn/cn/userguide/introduction

swagger基本注解@Tag、@Operation、@Parameters、@Parameter、@ApiResponse、@Schema

swagger基本注解 Tag 介紹&#xff1a;用于給接口分組&#xff0c;用途類似于為接口文檔添加標簽。用于&#xff1a;方法、類、接口。常用屬性&#xff1a; name&#xff1a;分組的名稱 RestController RequestMapping("/sysUser") Tag(name "管理員接口&quo…

Unity 實現幀率(FPS)顯示功能

一、功能介紹本教程實現一個 FPS 顯示腳本&#xff0c;支持 TextMeshProUGUI 組件。腳本會每秒更新一次幀率&#xff0c;并顯示在 UI 上&#xff0c;便于開發和調試時觀察性能變化。二、完整代碼將以下代碼保存為 FPS.cs 腳本&#xff1a;using UnityEngine; using TMPro;[Requ…