MyBatis中如何实现一个分页功能呢?
创始人
2024-02-22 06:22:22

转自:

MyBatis中如何实现一个分页功能呢?

分页可以毫不夸张的说:“是所有应用程序都必须拥有的操作模式”,那么MyBatis中如何实现一个数据库的分页取数据的功能呢?
下文将一一道来,如下所示:

实现思路:通过UserInfoMapper.xml中定义相应的sql脚本,
实现数据分页操作


例: UserInfoMapper中定义相应的方法

/**
*
* @param userInfo
* @param currentPageNo 起始位置
* @param pageSize      页面容量
* @return
*/
public List selectUserInfo(@Param("userInfo") UserInfo userInfo, @Param("from") Integer currentPageNo,@Param("pageSize") Integer pageSize);

UserInfoMapper.xml 中增加 limit 关键字,
SQL 映射代码

测试类

public static void main(String[] args) throws IOException {// 读取配置文件mybatis-config.xmlInputStream config = Resources.getResourceAsStream("mybatis-config.xml");// 根据配置文件构建SqlSessionFactory ssf = new SqlSessionFactoryBuilder().build(config);// 通过SqlSessionFactory创建SqlSessionSqlSession ss = ssf.openSession();UserInfo userInfo = new UserInfo();userInfo.setNotes("喜喜");Integer pageSize = 3;Integer currentPageNo = 0;List userList = new ArrayList();userList = ss.getMapper(UserInfoMapper.class).selectUserInfo(userInfo, currentPageNo, pageSize);for (UserInfo t : userList) {System.out.println(t);}
}

运行结果---
DEBUG [main] - ==> Preparing: SELECT id,name,notes FROM UserInfo where notes like concat ('%',?,'%') ORDER BY id limit ?,?
DEBUG [main] - ==> Parameters: 喜喜(String), 0(Integer), 3(Integer)
.....

相关内容

热门资讯

山东阳谷县通报:一公司石蜡料场... 情况通报2026年6月13日17时38分,山东阳谷华泰化工股份有限公司石蜡料场起火,市县立即组织力量...
采纳科技2025年参保人数14... 6月14日消息,据天眼查数据显示,采纳科技股份有限公司2025年参保人数为149人,较2024年披露...
劣质“迪卡侬”流向全国,有店铺... 据蓝鲸新闻6月14日报道,近日,记者接到大量消费者买到迪卡侬劣质产品的举报线索。记者在一些电商平台以...
市值暴增790亿!PCB“卖铲... 进入2026年,大族激光在资本市场上“一路长虹”。数据统计显示,截至最新收盘,大族激光年内股价涨幅突...
微光成炬!联动多方资源,这场公... (来源:上观新闻)2026年6月14日是第23个世界献血者日。近日,徐汇区漕河泾街道红十字会联合徐汇...