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)
.....

相关内容

热门资讯

301511,海外并购终止 1月11日晚,德福科技(301511)公告称,公司原计划以1.74亿欧元(按当前汇率,折合人民币约1...
贪官90件假古董卖了数千万贪官... 【#贪官90件假古董卖了数千万##贪官用古董买卖掩盖权钱交易#】据央视:农业农村部原部长唐仁健,通过...
​华泰证券:春季躁动进行时,转... 转自:证券时报人民财讯1月11日电,华泰证券研报称,近期,A股延续放量上涨,突破前高,风险偏好提升驱...
富瀚微收到证监会境外上市备案反... 近日,富瀚微收到中国证监会关于本次境外上市的备案反馈意见,监管具体问询事项如下:请你公司补充说明以下...
U23亚洲杯小组赛第二轮,中国... 北京时间1月11日晚,2026年U23亚洲杯足球赛D组第二轮,中国U23男足1-0击败澳大利亚U23...