【菜鸟学Java】3:封装一个分页类PageBean

        背景介绍:

        在做网上商城的项目时,有一个非常高频的功能需求,那就是做Web前端开发都知道的分页显示数据。当然要实现这个功能方法是非常多的,在我之前的做的项目接口管理系统中,使用的实现方式是假分页的方式,即将所有的数据查询出来,在前端进行分页,这个分页是使用前端框架的表格控件来完成的。因此我们在开发的时候,并没有在分页的实现上下多大的功夫,当然也就谈不上什么抽象和封装之类的编程技巧了。

        当然,真分页的方式也实现过,就是在底层封装一些分页查询的方法,将分页信息比如起始页以及每页显示多少条记录等参数信息传入,然后在方法内部使用原生的SQL和传入的参数一起组成SQL语句,执行SQL语句来实现分页。显然这也没有使用面向对象的思想来实现分页功能。

        那么如何用面向对象的方式来实现分页的功能呢?请往下看:

        正文部分:

        首先我们先来封装一个分页实体类PageBean,代码如下:

        分页类PageBean

        

<span style="font-size:18px;">public class PageBean<T> {
	private int page; //当前页数
	private int totalCount;  //总记录数
	private int totalPage;  //总页数
	private int limit;   //每页显示的记录数
	private List<T> list; //每页显示数据记录的集合;
	public int getPage() {
		return page;
	}
	public void setPage(int page) {
		this.page = page;
	}
	public int getTotalCount() {
		return totalCount;
	}
	public void setTotalCount(int totalCount) {
		this.totalCount = totalCount;
	}
	public int getTotalPage() {
		return totalPage;
	}
	public void setTotalPage(int totalPage) {
		this.totalPage = totalPage;
	}
	public int getLimit() {
		return limit;
	}
	public void setLimit(int limit) {
		this.limit = limit;
	}
	public List<T> getList() {
		return list;
	}
	public void setList(List<T> list) {
		this.list = list;
	}
	
}</span>

        那么如何使用封装好的分页类呢?接着往下看:

        Action类业务方法

        

<span style="font-size:18px;">//根据分类的ID查询商品
	public String findByCid(){
		
		PageBean<Product> pageBean=productService.findByPageCid(cid,page);//根据一级分类查询带分页的商品
		//将PageBean存入到值栈中
		ActionContext.getContext().getValueStack().set("pageBean", pageBean);
		return "findByCid";
	}</span>

        Service类业务方法

        

<span style="font-size:18px;">//根据一级分类的cid带分页的查询商品
	public PageBean<Product> findByPageCid(Integer cid, int page) {
		PageBean<Product> pageBean= new PageBean<Product>();
		//设置当前页数
		pageBean.setPage(page);
		//设置每页显示的记录数
		int limit =8;
		pageBean.setLimit(limit);
		//设置总记录数
		int totalCount=0;
		totalCount = productDao.findCountCid(cid);
		pageBean.setTotalCount(totalCount);
		//设置总页数
		int totalPage=0;
		if(totalCount % limit ==0){
			totalPage=totalCount/limit;
			
		}else {
			totalPage= totalCount/limit +1;
		}
		pageBean.setTotalPage(totalPage);
		//每页显示的数据集合
		//从哪开始
		int begin=(page-1)*limit;
		List<Product> list=productDao.findByPageCid(cid,begin,limit);
		pageBean.setList(list);
		return pageBean;
	}</span>

        Dao类业务方法

        

<span style="font-size:18px;">public List<Product> findByPageCid(Integer cid, int begin, int limit) {
		String hql="select p from Product p join p.categorySecond cs join cs.category c where c.cid=?";
		//分页的另一种方法
		List<Product> list=this.getHibernateTemplate().execute(new PageHibernateCallback<Product>(hql, new Object[]{cid}, begin, limit));
		if(list!=null && list.size()>0){
			return list;
		}
		return null;
	}</span>

        小结一下:

        其实在之前做的项目中根本没有想到过使用类去对分页进行封装,在遇到分页的功能需求时,总是想着底层分页方法的编写和客户端分页如何实现,亦或是借助前端分页控件实现,将面向对象的编程思想跑到了九霄云外,可能是对面向对象的理解还不够深刻,因此根本没有那个想法,不怕不知道,就怕不知道,就是这个道理。

  • 3
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 10
    评论
### 回答1: MyBatis-Plus可以使用Java代码来实现分页查询,具体步骤如下:1. 在Mapper文件中定义SQL语句;2. 创建Page对象;3. 调用Mapper.selectPage方法执行查询;4. 使用Page对象获取分页结果。 ### 回答2: Mybatis-Plus是一个开源的JPA持久层框架,提供了许多方便实用的功能,其中包括了分页查询的支持。下面是使用Java代码实现分页查询的步骤: 1. 首先,需要在项目的依赖中添加Mybatis-Plus的相关依赖,可以通过Maven或者Gradle来管理依赖。 2. 在实体中引入Page对象,该对象用于封装分页查询的结果信息。 ```java import com.baomidou.mybatisplus.extension.plugins.pagination.Page; public class User { private Long id; private String name; private Integer age; // 省略getter和setter方法 } ``` 3. 创建Mapper接口,该接口继承自BaseMapper,并使用@Mapper注解标注。在接口中定义分页查询的方法。 ```java import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import org.apache.ibatis.annotations.Mapper; @Mapper public interface UserMapper extends BaseMapper<User> { Page<User> selectUserPage(Page<User> page); } ``` 4. 在Mapper.xml文件中编写SQL语句,实现分页查询的逻辑。 ```xml <mapper namespace="com.example.mapper.UserMapper"> <select id="selectUserPage" resultType="com.example.entity.User"> select * from user </select> </mapper> ``` 5. 在Service层中调用Mapper接口的分页查询方法,并传入Page对象和查询条件。 ```java import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; @Service public class UserServiceImpl implements UserService { @Autowired private UserMapper userMapper; @Override public Page<User> getUserPage(int pageNum, int pageSize) { Page<User> page = new Page<>(pageNum, pageSize); userMapper.selectUserPage(page); return page; } } ``` 6. 最后,在Controller层调用Service层的方法,并将得到的分页结果返回给前端。 ```java import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.example.entity.User; import com.example.service.UserService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; @RestController public class UserController { @Autowired private UserService userService; @GetMapping("/users") public Page<User> getUserPage(@RequestParam int pageNum, @RequestParam int pageSize) { return userService.getUserPage(pageNum, pageSize); } } ``` 通过以上步骤,我们就可以使用Java代码实现分页查询了。在Controller层的接口中,可以通过传入pageNum和pageSize参数来指定查询的页数和每页的大小,然后通过Service层的方法调用Mapper层的方法,并将查询结果封装Page对象中返回给前端。 ### 回答3: Mybatis-plus是一个基于Mybatis的ORM框架,提供了很多便捷的操作方法,包括分页查询。下面是使用Java代码实现分页查询的示例: 1. 首先,创建一个实体,与数据库中的表对应,定义实体的属性和对应的表字段。 ```java public class User { private Long id; private String name; private Integer age; // 省略 getter 和 setter 方法 } ``` 2. 在Mapper接口中定义分页查询的方法。 ```java public interface UserMapper extends BaseMapper<User> { List<User> selectPage(Page<User> page); } ``` 3. 在ServiceImpl中实现分页查询的方法。 ```java @Service public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService { @Override public Page<User> getUserByPage(int pageNum, int pageSize) { Page<User> page = new Page<>(pageNum, pageSize); page.setTotal(baseMapper.selectCount(null)); List<User> userList = baseMapper.selectPage(page); page.setRecords(userList); return page; } } ``` 4. 在Controller中调用分页查询的方法,并返回结果给前端。 ```java @RestController public class UserController { @Autowired private UserService userService; @GetMapping("/users") public Page<User> getUsers(@RequestParam("pageNum") int pageNum, @RequestParam("pageSize") int pageSize) { return userService.getUserByPage(pageNum, pageSize); } } ``` 以上就是使用Java代码实现分页查询的步骤。在实际项目中,可以根据需要进行调整和扩展,但整体思路是似的。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值