Mybatis分页的实现
**当我们在查询大量数据的时候,我们往往使用分页进行查询,也就是每次处理小部分数据,这样对数据库压力就在可控范围内。Mybaits实现分页的方式主要有Limit分页、RowBounds分页和PageHelper分页。**
一.Limit分页的实现(在SQL层面进行分页)
1 //Limit分页的实现语法 2 SELECT * FROM table LIMIT startIndex,pageSize 3 //startIndex 分页的起始页的前一页,即分页查询的页码是以startIndex+1页开始的。pageSize分页搜寻的行数 4 5 SELECT * FROM table LIMIT 5,10; // 检索记录行 6-15 6 7 //为了检索从某一个偏移量到记录集的结束所有的记录行,可以指定第二个参数为 -1。 8 SELECT * FROM table LIMIT 95,-1; // 检索记录行 96-last.(即从96到在以后一行) 9 10 //如果只给定一个参数,它表示返回最大的记录行数目: 11 //换句话说,LIMIT n 等价于 LIMIT 0,n。 12 SELECT * FROM table LIMIT 5; //检索前 5 个记录行
编写步骤:
1.修改Mapper文件
<select id = "selectUser" parameterType = "map" resultType = "user"> select * from user limit #{startIndex},#{pageSize} </select>
2.Mapper接口,参数为map
List<user> selectUser(Map<String,Intrger> map); //选择全部用户实现分页
3.在测试类中传入参数测试
//分页查询 , 两个参数startIndex , pageSize @Test public void testSelectUser() { SqlSession session = MybatisUtils.getSession(); UserMapper mapper = session.getMapper(UserMapper.class); int currentPage = 1; //第几页 int pageSize = 2; //每页显示几个 Map<String,Integer> map = new HashMap<String,Integer>(); map.put("startIndex",(currentPage-1)*pageSize); map.put("pageSize",pageSize); List<User> users = mapper.selectUser(map); for (User user: users){ System.out.println(user); } session.close(); }
二、RowBounds分页(在java代码层面实现分页)
步骤:
1.mapper接口
//选择全部用户RowBounds实现分页 List<User> getUserByRowBounds();
2.mapper文件
<select id="getUserByRowBounds" resultType="user"> select * from user </select>
3.测试类
@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<User> users = session.selectList("com.kuang.mapper.UserMapper.getUserByRowBounds", null, rowBounds); for (User user: users){ System.out.println(user); } session.close(); }
本文来自博客园,作者:已不知落在何地,转载请注明原文链接:https://www.cnblogs.com/yongweijian/p/16324050.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!