分页
MyBatis 的分页功能是基于内存的分页,即先查询出所有记录,再按起始位置和页面容量取出结果。
示例
WebsiteMapper
/** * * @param site * @param currentPageNo 起始位置 * @param pageSize 页面容量 * @return */ public List<Website> selectWebsite(@Param("site") Website site, @Param("from") Integer currentPageNo, @Param("pageSize") Integer pageSize);
WebsiteMapper.xml 的查询语句,增加 limit 关键字,SQL 映射代码如下
<select id="selectWebsite" resultType="net.biancheng.po.Website"> SELECT id,name,url,age,country FROM website <trim prefix="where" prefixOverrides="and"> <if test="site.name != null and site.name !=''"> AND name LIKE CONCAT ('%',#{site.name},'%') </if> <if test="site.url!= null and site.url !=''"> AND url LIKE CONCAT ('%',#{site.url},'%') </if> ORDER BY id limit #{from},#{pageSize} </trim> </select>
上述代码中,根据传入的起始位置(currentPageNo=0)和页面容量(pageSize=3)进行相应分页,查看第一页的数据列表,运行测试方法,输出正确的分页列表。
注意:MyBatis 实现分页查询属于 DAO 层操作,由于 DAO 层不牵涉任何业务实现,所以实现分页的方法中第一个参数为 limit 的起始位置(下标从 0 开始),而不是用户输入的真正页码(页码从1开始)。
页码如何转换为 limit 的起始位置下标,即:起始位置下标=(页码-1)*页面容量,
那么这个转换操作必然不能在 DAO 层实现,需要在业务层实现。所以我们在测试类中传入的参数为下标,而不是页码。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)