limit分页在这之前学习servlet就实现过
select * from table_name limit startIndex,pagesize
再由简易的算法实现 每次点击下一页来更改pagesize以及startIndex的值。
为什么需要分页?
在学习mybatis等持久层框架的时候,会经常对数据进行增删改查操作,使用最多的是对数据库进行查询操作,如果查询大量数据的时候,我们往往使用分页进行查询,也就是每次处理小部分数据,这样对数据库压力就在可控范围内。
之前MySQL修复的bug
select * from table_name limit 3,-1
-1在未修复时 是可以作为查询的最大页数 也是可以查处结果的,修复之后 这样的写法会报错。
mybatis框架的limit分页查询:
#语法
SELECt * FROM table LIMIT stratIndex,pageSize
SELECt * FROM table LIMIT 5,10; // 检索记录行 6-15 后面的数字表示显示几个
#为了检索从某一个偏移量到记录集的结束所有的记录行,可以指定第二个参数为 -1:
SELECt * FROM table LIMIT 95,-1; // 检索记录行 96-last.
#如果只给定一个参数,它表示返回最大的记录行数目:
SELECt * FROM table LIMIT 5; //检索前 5 个记录行
#换句话说,LIMIT n 等价于 LIMIT 0,n。
mapper增加方法:
Listlimiter(Map map);
.xml:
select * from hero limit #{StartIndex},#{pagesize}
@test:
@Test
public void limitSelect()
{
SqlSession sqlSession=MyBatisTool.getSqlSession();
HeroDAO heroDAO=sqlSession.getMapper(HeroDAO.class);
Map map=new HashMap();
map.put("StartIndex",0);
map.put("pagesize",2);
List hero=heroDAO.limiter(map);
for(heros heri:hero)
{
System.out.println(heri);
}
sqlSession.close();
}
进行分页时一般计算公式—— 起始位置 = (当前页面 - 1 ) * 页面大小
RowBounds分页
RowBounds 实质为一个类 使用时实例化一个对象 传入即可 并不是sql层面去查询而是Java层面
该方法被用来查询的频率不是很大 作为了解
1、mapper接口
//选择全部用户RowBounds实现分页 ListgetUserByRowBounds();
2、mapper文件
3、测试类
在这里,我们需要使用RowBounds类
@Test
public void testUserByRowBounds() {
SqlSession session = MybatisUtils.getSession();
int currentPage = 2; //第几页
int pageSize = 2; //每页显示几个
RowBounds rowBounds = new RowBounds((currentPage-1)*pageSize,pageSize);
//通过session.**方法进行传递rowBounds,[此种方式现在已经不推荐使用了]
List users = session.selectList("getUserByRowBounds", null, rowBounds);
for (User user: users){
System.out.println(user);
}
session.close();
}
除此之外还有 mybatis的分页插件——官方文档pagehelper
实现更高效的查询工作。



