第五讲 分页的实现

一、分析mysql的分页语句:limit startIndex, pageSize

      mapper映射文件:

     <!-- 查询所有用户 -->
     <select id="selectAll" parameterType="Map" resultType="User">
           select * from user limit #{startIndex}, #{pageSize}
     </select>

      dao中的写法:

      //分页查询
     public List<User> getAll(int currentPage, int pageSize) throws IOException {
           SqlSession session = MyBatisUtil.getSqlSession();
           
           Map<String, Integer> map = new HashMap<String, Integer>();
           map.put("startIndex", (currentPage - 1) * pageSize);
           map.put("pageSize", pageSize);
           
           List<User> list = session.selectList("com.liujie.model.UserMapper.selectAll", map);
           
           session.close();
           return list;
     }

   注意:不用为参数设置类,可以采用Map结构来解决这个问题

二、通过RowBounds来实现分页

      mapper映射文件不需要做任何改变:

     <!-- 查询所有用户 -->
     <select id="selectAll" resultType="User">
           select * from user
     </select>

      dao中需要新建RowBounds对象:

RowBounds rowBounds = new RowBounds(pageIndex , pageSize );
public RowBounds( int offset , int limit )

     //分页查询
     public List<User> getAll(int currentPage, int pageSize) throws IOException {
           SqlSession session = MyBatisUtil.getSqlSession();
           
           RowBounds rowBounds = new RowBounds((currentPage-1)*pageSize, pageSize);  
           List<User> list = session.selectList("com.liujie.model.UserMapper.selectAll", null, rowBounds);
           
           session.close();
           return list;
     }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值