首页 > Mybatis 阅读:12179

MyBatis分页功能

通义灵码
MyBatis 的分页功能是基于内存的分页,即先查询出所有记录,再按起始位置和页面容量取出结果。

本节我们为查询网站记录增加分页功能,要求结果列表按照 id 升序排列(本节示例基于《第一个MyBatis程序》一节的代码实现)。

WebsiteMapper 中方法如下。
  1. /**
  2. *
  3. * @param site
  4. * @param currentPageNo 起始位置
  5. * @param pageSize 页面容量
  6. * @return
  7. */
  8. public List<Website> selectWebsite(@Param("site") Website site, @Param("from") Integer currentPageNo,
  9. @Param("pageSize") Integer pageSize);
相比原来的 selectWebsite 方法,增加了两个参数,起始位置(from)和页面容量(pageSize),用于实现分页查询。

修改 WebsiteMapper.xml 的查询语句,增加 limit 关键字,SQL 映射代码如下。
  1. <select id="selectWebsite" resultType="net.biancheng.po.Website">
  2. SELECT id,name,url,age,country
  3. FROM website
  4. <trim prefix="where" prefixOverrides="and">
  5. <if test="site.name != null and site.name !=''">
  6. AND name LIKE CONCAT ('%',#{site.name},'%')
  7. </if>
  8. <if test="site.url!= null and site.url !=''">
  9. AND url LIKE CONCAT ('%',#{site.url},'%')
  10. </if>
  11. ORDER BY id limit #{from},#{pageSize}
  12. </trim>
  13. </select>
测试类代码如下。
  1. public static void main(String[] args) throws IOException {
  2.  
  3. // 读取配置文件mybatis-config.xml
  4. InputStream config = Resources.getResourceAsStream("mybatis-config.xml");
  5. // 根据配置文件构建
  6. SqlSessionFactory ssf = new SqlSessionFactoryBuilder().build(config);
  7. // 通过SqlSessionFactory创建SqlSession
  8. SqlSession ss = ssf.openSession();
  9.  
  10. Website site = new Website();
  11. // site.setname("编程");
  12. site.setUrl("http");
  13.  
  14. Integer pageSize = 3;
  15. Integer currentPageNo = 0;
  16.  
  17. List<Website> siteList = new ArrayList<Website>();
  18. siteList = ss.getMapper(WebsiteMapper.class).selectWebsite(site, currentPageNo, pageSize);
  19.  
  20. for (Website ws : siteList) {
  21. System.out.println(ws);
  22. }
  23.  
  24. }
运行结果如下。

DEBUG [main] - ==>  Preparing: SELECT id,name,url,age,country FROM website where url like concat ('%',?,'%') ORDER BY id limit ?,?
DEBUG [main] - ==> Parameters: http(String), 0(Integer), 3(Integer)
DEBUG [main] - <==      Total: 3
Website[id=1,name=编程帮,url=https://www.biancheng.net/,age=10,country=CN]
Website[id=2,name=C语言中文网,url=http://c.biancheng.net/,age=12,country=CN]
Website[id=3,name=百度,url=https://www.baidu.com/,age=18,country=CN]

上述代码中,根据传入的起始位置(currentPageNo=0)和页面容量(pageSize=3)进行相应分页,查看第一页的数据列表,运行测试方法,输出正确的分页列表。

注意:MyBatis 实现分页查询属于 DAO 层操作,由于 DAO 层不牵涉任何业务实现,所以实现分页的方法中第一个参数为 limit 的起始位置(下标从 0 开始),而不是用户输入的真正页码(页码从1开始)。在 JSP 教程的《JSP分页》一节已经学习过页码如何转换为 limit 的起始位置下标,即:起始位置下标=(页码-1)*页面容量,那么这个转换操作必然不能在 DAO 层实现,需要在业务层实现。所以我们在测试类中传入的参数为下标,而不是页码。