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增加方法:
List<heros> limiter(Map<String,Integer> map);
.xml:
<select id="limiter" parameterType="map" resultType