hibernate分页实现
1.创建分页实体类 public class PageBean { private int page; // 页码 private int rows; // 每页显示行数 private int start; // 某一页从第几条开始 public PageBean(int page, int rows) { super(); this.page = page; this.rows = rows; } public int getPage() { return page; } public void setPage(int page) { this.page = page; } public int getRows() { return rows; } public void setRows(int rows) { this.rows = rows; } public int getStart() { return (page-1)*rows; } } 2.daoImpl public List<Grade> gradeList(PageBean pageBean,Grade grade)throws Exception{ List<Grade> gradeList=null; Session session=this.getSession(); StringBuffer sb=new StringBuffer("from Grade g"); if(grade!=null && StringUtil.isNotEmpty(grade.getGradeName())){ sb.append(" and g.gradeName like '%"+grade.getGradeName()+"%'"); } Query query=session.createQuery(sb.toString().replaceFirst("and", "where")); if(pageBean!=null){ query.setFirstResult(pageBean.getStart()); query.setMaxResults(pageBean.getRows()); } gradeList=(List<Grade>)query.list(); return gradeList; } 3.Action public String execute() throws Exception { PageBean pageBean=new PageBean(Integer.parseInt(page),Integer.parseInt(rows)); try{ if(grade==null){ grade=new Grade(); } grade.setGradeName(s_gradeName); JSONObject result=new JSONObject(); List<Grade> gradeList=gradeService.gradeList(pageBean, grade); JSONArray jsonArray=new JSONArray(); for(int i=0;i<gradeList.size();i++){ Grade grade=(Grade)gradeList.get(i); JSONObject jsonObject=new JSONObject(); jsonObject.put("id", grade.getId()); jsonObject.put("gradeName", grade.getGradeName()); jsonObject.put("gradeDesc", grade.getGradeDesc()); jsonArray.add(jsonObject); } int total=gradeService.gradeCount(grade); result.put("rows", jsonArray); result.put("total", total); ResponseUtil.write(ServletActionContext.getResponse(), result); }catch(Exception e){ e.printStackTrace(); } return null; }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理