手动分页

/**
	 * @createTime  2019年7月15日上午10:48:17
	 * @description 手动分页
	 */
	public static <T> List<T> manualPaging(List<T> list,int page,int sizeEach){
		List<T> listTemp = new ArrayList<T>();
		int size = list.size();
		if (size < 1) {
			return listTemp;
		}
		int listSize = list.size();
		int startIndex = (page - 1) * sizeEach;// 起点索引
		int endIndex = page * sizeEach - 1;// 终点索引
		int maxIndex = listSize - 1;// 集合容量的最大索引
//		if (maxIndex < startIndex) {
//			return listTemp;
//		} else 
		if (startIndex <= maxIndex && maxIndex < endIndex) {
			for (int i = startIndex; i <= maxIndex; i++) {
				listTemp.add(list.get(i));
			}
		} else if (endIndex <= maxIndex) {
			for (int i = startIndex; i <= endIndex; i++) {
				listTemp.add(list.get(i));
			}
		}
		return listTemp;
	}

  

手动分页是指通过在代码中手动实现分页功能,而非通过使用MyBatis的分页插件或其他自动化方式来实现分页功能。 实现手动分页的方法有多种,以下是其中一种常用的方法: 1. 首先,在SQL语句中添加LIMIT关键字,指定需要查询的数据范围。LIMIT语法通常是在查询语句的末尾使用,可以指定返回结果的起始位置和数量。例如,LIMIT 10表示从第一条记录开始,返回10条记录。 2. 在Java代码中,根据用户传入的页码和每页显示的记录数计算出需要查询的起始位置,并将其作为参数传递给SQL语句。 3. 执行查询操作,并将查询结果返回给用户。 以下是一个示例代码片段,演示了如何在MyBatis中手动实现分页功能: ```java public interface UserDao { List<User> getUsers(@Param("start") int start, @Param("pageSize") int pageSize); } public class UserService { @Autowired private UserDao userDao; public List<User> getUsersByPage(int pageNum, int pageSize) { int start = (pageNum - 1) * pageSize; return userDao.getUsers(start, pageSize); } } ``` 在上述示例中,`UserDao`接口包含了一个名为`getUsers`的方法,该方法接受`start`和`pageSize`作为参数。在`UserDao`的实现类中,可以使用`LIMIT`关键字将查询结果限制在指定的范围内。`UserService`类调用`getUsersByPage`方法并传入页码和每页显示的记录数,然后计算起始位置,并将其传递给`getUsers`方法。 总结起来,手动分页是通过在SQL语句中使用LIMIT关键字,结合Java代码中的计算逻辑,实现对数据的手动分页操作。这种方式相对简单,但需要手动处理页码和起始位置的计算。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值