MyBatis 分頁插件使用教程

MyBatis 分頁插件使用教程

MyBatis 是一款優秀的持久層框架,但原生的 MyBatis 并不支持分頁查詢。為了簡化分頁操作,MyBatis 官方和第三方提供了多種分頁插件,最常用的就是 MyBatis-Plus 的分頁插件。本文詳細介紹 MyBatis-Plus 分頁插件的使用方法。

1. 什么是分頁插件

分頁插件的作用是攔截查詢 SQL,在執行查詢之前或之后自動拼接分頁相關的 SQL,幫助開發者簡化分頁處理邏輯,無需手動拼接 LIMIT 和 OFFSET。

2. 環境準備

引入 MyBatis-Plus 依賴

<dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.5.3.1</version>
</dependency>

配置分頁插件

創建配置類:

@Configuration
public class MybatisPlusConfig {@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));return interceptor;}
}

3. 分頁查詢使用示例

實體類示例

@Data
public class User {private Long id;private String name;private Integer age;
}

Mapper 接口

@Mapper
public interface UserMapper extends BaseMapper<User> {
}

分頁查詢示例

@Autowired
private UserMapper userMapper;@Test
public void testPage() {Page<User> page = new Page<>(1, 5); // 第1頁,每頁5條Page<User> userPage = userMapper.selectPage(page, null);System.out.println("總記錄數: " + userPage.getTotal());System.out.println("總頁數: " + userPage.getPages());userPage.getRecords().forEach(System.out::println);
}

4. 帶條件的分頁查詢

QueryWrapper<User> queryWrapper = new QueryWrapper<>();
queryWrapper.ge("age", 20);Page<User> page = new Page<>(1, 3);
Page<User> userPage = userMapper.selectPage(page, queryWrapper);

5. 注意事項

  • 分頁插件需要配置 MybatisPlusInterceptor
  • Page 對象的兩個重要參數:
    • 當前頁數 current
    • 每頁顯示條數 size
  • 分頁結果包含:
    • 總記錄數 total
    • 總頁數 pages
    • 當前頁數據 records

6. 小結

MyBatis-Plus 分頁插件極大簡化了分頁查詢的實現,開發者無需關心底層的 SQL 拼接,只需傳入分頁參數即可快速完成分頁查詢。它是企業開發中非常實用的功能,推薦在 MyBatis 項目中廣泛使用。

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

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

相關文章

目錄穿越 + pickle反序列化 -- xyctf Signin WP

源代碼 # -*- encoding: utf-8 -*-File : main.py Time : 2025/03/28 22:20:49 Author : LamentXUflag in /flag_{uuid4}from bottle import Bottle, request, response, redirect, static_file, run, route secret aapp Bottle() route(/) def index():return…

區塊鏈技術:重塑供應鏈管理的未來

在當今全球化的商業環境中&#xff0c;供應鏈管理的復雜性和重要性日益凸顯。從原材料采購到產品交付&#xff0c;供應鏈的每一個環節都可能影響企業的運營效率和客戶滿意度。隨著區塊鏈技術的興起&#xff0c;供應鏈管理迎來了新的變革機遇。本文將深入探討區塊鏈技術在供應鏈…

ragflow本地部署(WSL下Ubuntu)

本地docker及 docker-compose版本 安裝參考&#xff1a; 實踐筆記-docker安裝及配置鏡像源實踐筆記-docker-compose安裝 1.下載源碼 git clone https://github.com/infiniflow/ragflow.git2.運行docker-compose拉取鏡像 cd ragflow/docker docker-compose up -d3.啟動報錯…

LTSPICE仿真電路:(二十六)跨阻放大器簡單仿真

1.前言 由于有個機會剛好了解了下跨阻&#xff0c;簡單做個這個仿真&#xff0c;實際上跨阻放大器應該要復雜的多&#xff0c;由于跨阻放大器實際上是將電流轉換為電壓&#xff0c;最需要注意的參數肯定是運放的偏置電流 2.跨阻放大器仿真 這篇是純記錄 這是一個將0-50uA電流…

androd的XML頁面 跳轉 Compose Activity 卡頓問題

解決 XML 點擊跳轉到 Compose Activity 卡頓問題 當從 XML 布局的 Activity 跳轉到 Compose Activity 時出現卡頓現象&#xff0c;這通常是由以下幾個原因導致的&#xff1a; 可能的原因及解決方案 1. Compose 首次初始化開銷 問題&#xff1a;Compose 框架首次初始化需要時…

基于Python的二手房數據挖掘與可視化深度分析

一、技術框架與數據概況 1.1 技術棧構成 import pandas as pd # 數據操作(v1.3.5) import numpy as np # 數值計算(v1.21.6) from pyecharts.charts import * # 交互式可視化(v1.9.1) from sklearn.preprocessing import StandardScaler # 數據標準化(可選擴展) …

從數據到成果:R 語言在氣象水文全流程中的關鍵技術應用

R語言在氣象、水文中數據處理及結果分析、繪圖實踐技術應用 R 語言是一門由統計學家開發的用于統計計算和作圖的語言&#xff08;a Statistic Language developed for Statistic by Statistician&#xff09;&#xff0c;由 S 語言發展而來&#xff0c;以統計分析功能見長。R …

2025最快解決root密碼忘記問題或重置root密碼root密碼忘記了怎么辦?如何最方便的找回或者重置root密碼?

root密碼忘記了怎么辦&#xff1f;如何最方便的找回或者重置root密碼&#xff1f; 1、完全不需要按照網絡上的那么麻煩的操作 2、看看我們機房的物理服務器有沒有默認的管理地址&#xff0c;如果有的話我們就把自己的電腦調整跟服務器一樣的網段&#xff0c;用瀏覽器訪問該服務…

面試題匯總06-場景題線上問題排查難點亮點

面試題匯總06-場景題&線上問題排查&難點亮點 【一】場景題【1】訂單到期關閉如何實現【2】每天100w次登錄請求,4C8G機器如何做JVM調優?(1)問題描述和分析(2)堆內存設置(3)垃圾收集器選擇(4)各區大小設置(5)添加必要的日志【3】如果你的業務量突然提升100倍…

C和C++有什么區別?

C和C是兩種不同的編程語言&#xff0c;雖然它們有許多相似之處&#xff0c;但也存在一些關鍵的區別。 C是一種過程化編程語言&#xff0c;專注于函數和流程控制&#xff0c;非常適合系統級編程。而 C是一種面向對象編程語言&#xff0c;支持類、對象和封裝、繼承、多態等特性。…

動態規劃-楊輝三角

118.楊輝三角 給定一個非負整數 numRows&#xff0c;生成「楊輝三角」的前 numRows 行。輸入&#xff1a;int 輸出&#xff1a;二元列表 思路&#xff1a; 面向結果編程&#xff01;&#xff01;&#xff01; class Solution {public List<List<Integer>> genera…

powershell綁定按鈕事件的兩種方式

寫一個powershell的簡單GUI做本地任務&#xff0c;試驗出2個方法&#xff1a; 方法1&#xff1a; function btn1_click {write-host $text1.Text -ForegroundColor Green -BackgroundColor Black }$btn1.Add_Click({btn1_click})方法2&#xff1a; $btn2_click {write-host $…

C++語言的并查集

并查集&#xff08;Union-Find&#xff09;在C中的實現與應用 引言 并查集&#xff08;Union-Find&#xff09;&#xff0c;又稱為不相交集合&#xff08;Disjoint Set&#xff09;&#xff0c;是一種用于處理動態連通性問題的數據結構。它的主要功能包括合并兩個集合&#x…

基于大模型的病態竇房結綜合征預測及治療方案研究報告

目錄 一、引言 1.1 研究背景與目的 1.2 研究意義 二、病態竇房結綜合征概述 2.1 定義與病因 2.2 臨床表現與分型 2.3 診斷方法 三、大模型在病態竇房結綜合征預測中的應用 3.1 大模型介紹 3.2 數據收集與預處理 3.3 模型訓練與優化 四、術前預測與準備 4.1 風險預…

2026考研數學張宇武忠祥復習視頻課,高數基礎班+講義PDF

2026考研數學武忠祥老師課&#xff08;網盤&#xff09;&#xff1a;點擊下方鏈接 2026考研數學武忠祥網課&#xff08;最新網盤&#xff09; 一、基礎階段&#xff08;3-5個月&#xff09; 目標&#xff1a;搭建知識框架掌握基礎題型 教材使用&#xff1a; 高數&#xff1a;…

linux命令二

1.將windows文件上傳到linux 將文件傳到光驅里&#xff0c;再將光驅進行掛載&#xff0c;mount 2.linux安裝的文件存儲 普通執行 程序 bin 配置文件 /etc 日志文件 /var/log 3.rpm 主查詢 命令&#xff1a;rpm -q 包名 查詢已安裝的軟件包 通過軟件 -qa 查詢所有已安裝的軟件包…

k8s的StorageClass存儲類和pv、pvc、provisioner、物理存儲的鏈路

k8s的StorageClass存儲類和pv、pvc、provisioner、物理存儲的鏈路 StorageClass能自動創建pv 在控制器中&#xff0c;直接聲明storageClassName&#xff0c;不僅能自動創建pvc&#xff0c;也能自動創建pv stoageclass來自于provisioner&#xff0c;provisioner來自于pod&#x…

systemd 與 SysVinit

1. 什么是 systemd 和 SysVinit&#xff1f; systemd 和 SysVinit 都是 Linux 的初始化系統&#xff08;init system&#xff09;&#xff0c;用于管理系統啟動、服務、進程和日志。 比較項SysVinitsystemd啟動方式逐步啟動&#xff08;串行&#xff09;并行啟動&#xff08;…

QML菜單控件:菜單的常規用法

目錄 引言&#x1f4da;相關閱讀&#x1f528;BUG修復工程結構示例詳解示例1&#xff1a;上下文菜單&#xff08;ContextMenu&#xff09;示例2&#xff1a;菜單欄&#xff08;MenuBar&#xff09;示例3&#xff1a;動態菜單示例4&#xff1a;快捷鍵菜單示例5&#xff1a;可選項…

【Vue-路由案例】面經基礎版

目錄 <<回到導覽1.面經基礎版1.1.VueCli建項目1.1.1.VueCli 自定義項目1.1.2.ESlint代碼規范 1.2.項目路由1.2.1.一級路由配置1.2.2.二級配置路由1.2.3.設置高亮1.2.4.發生請求、渲染1.2.5.跳轉傳參、再發請求1.2.6.體驗優化1.2.7.keep-alive <<回到導覽 1.面經基…