mybatis+oracle+springMVC实现简单分页
2013-03-04 17:36
816 查看
mybatis+oracle+springMVC实现简单分页
1,先在网上看了大量的资料觉得均不靠谱。PM说只是需要实现一个简单的分页功能就OK,直接在sql里面实现即可2,首先是mybatis映射文件的配置问题
因为mybatis不能直接解析xml里面的<=,而在oracle里面暂且想到的sql语句需要用到,经过调试
实现的xml映射文件:
<select id="" parameterType="" resultType="" resultMap=""> Select ROWNUM,ID,NAME FROM(Select ROWNUM as ROWNO, ID,NAME from CHANGED_CONTENT <where> <![CDATA[ROWNUM <= #{endRow}]]> </where> ) <where> <![CDATA[ROWNO > #{startRow}]]> </where> </select>
3,下面就是Pager和PagerHelp类
Pager:
public class Pager { private int totalRows; // 总行数 private int pageSize = 1; // 每页显示的行数 private int currentPage; // 当前页号 private int totalPages; // 总页数 private int startRow; // 当前页在数据库中的起始行 private int endRow; //结束行 此为oracle查询需要增加 public Pager() { } public Pager(int _totalRows) { totalRows = _totalRows; totalPages = totalRows / pageSize; int mod = totalRows % pageSize; if (mod > 0) { totalPages++; } currentPage = 1; startRow = 0; } public int getStartRow() { return startRow; } public int getTotalPages() { return totalPages; } public int getCurrentPage() { return currentPage; } public int getPageSize() { return pageSize; } public void setTotalRows(int totalRows) { this.totalRows = totalRows; } public void setStartRow(int startRow) { this.startRow = startRow; } public void setTotalPages(int totalPages) { this.totalPages = totalPages; } public void setCurrentPage(int currentPage) { this.currentPage = currentPage; } public void setPageSize(int pageSize) { this.pageSize = pageSize; } public int getTotalRows() { return totalRows; } public void setEndRow(int endRow) { this.endRow = endRow; } public void first() { currentPage = 1; startRow = 0; } public void previous() { if (currentPage == 1 || currentPage == 0) { return; } currentPage--; startRow = (currentPage - 1) * pageSize; } public void next() { if (currentPage < totalPages) { currentPage++; } startRow = (currentPage - 1) * pageSize; } public void last() { currentPage = totalPages; startRow = (currentPage - 1) * pageSize; } } }
PageHelper:
public class PagerHelper { public static Pager getPager(HttpServletRequest httpServletRequest,int totalRows) { //定义pager对象,用于传到页面 Pager pager = new Pager(totalRows); //从Request对象中获取当前页号 String currentPage = httpServletRequest.getParameter("currentPage"); //如果当前页号为空,表示为首次查询该页 //如果不为空,则刷新pager对象,输入当前页号等信息 if (currentPage != null) { pager.refresh(Integer.parseInt(currentPage)); } //获取当前执行的方法,首页,前一页,后一页,尾页。 String pagerMethod = httpServletRequest.getParameter("pageMethod"); if (pagerMethod != null) { if (pagerMethod.equals("first")) { pager.first(); } else if (pagerMethod.equals("previous")) { pager.previous(); } else if (pagerMethod.equals("next")) { pager.next(); } else if (pagerMethod.equals("last")) { pager.last(); } } return pager; } }
4,下面就是在spring control里面实现与前台的jsp页面交互,当然还有service及serviceImpl里面主要是通过映射文件配置的sql返回对应的list
此处略
5,jsp页面相关代码:
function first(obj){ var currentPage = obj; if(1 < currentPage){ var url = "findcontent.do?pageMethod=first¤tPage="+currentPage; document.all.form1.method = "post"; document.all.form1.action = url; document.all.form1.submit(); }else{ alert("已经是首页了"); } } function previous(obj){ var currentPage = obj; if(1 < currentPage){ var url = "findcontent.do?pageMethod=previous¤tPage="+currentPage; document.all.form1.method = "post"; document.all.form1.action = url; document.all.form1.submit(); }else{ alert("已经是最前一页了"); } } function next(obj,totalPages){ var currentPage = obj; if(currentPage < totalPages){ var url = "findcontent.do?pageMethod=next¤tPage="+currentPage; document.all.form1.method = "post"; document.all.form1.action = url; document.all.form1.submit(); }else{ alert("已经是最后一页了"); } } function last(obj,totalPages){ var currentPage = obj; if(currentPage < totalPages){ var url = "findcontent.do?pageMethod=last¤tPage="+currentPage; document.all.form1.method = "post"; document.all.form1.action = url; document.all.form1.submit(); }else{ alert("已经是尾页了"); } }
<tr> <td colspan="2"> 第<%=pager.getCurrentPage()%>页 共<%=pager.getTotalPages()%>页 <a href="#" onclick="first(<%=pager.getCurrentPage()%>)">首页</a> <a href="#" onclick="previous(<%=pager.getCurrentPage()%>)">上一页</a> <a href="#" onclick="next(<%=pager.getCurrentPage()%>,<%=pager.getTotalPages()%>)">下一页</a> <a href="#" onclick="last(<%=pager.getCurrentPage()%>,<%=pager.getTotalPages()%>)">尾页</a> </td> </tr>
至此便实现了此架构下的简单分页功能
相关文章推荐
- springmvc + myBatis + boostrap技术下简单实现的前后端分页功能
- 分页查询简单实现(Freemarker+SpringMVC+Mybatis)
- springmvc+Mybatis 分页查询的简单实现
- Maven+Mybatis+Spring+SpringMVC实现(oracle)分页查询(附源码)
- SpringMVC+Mybatis+Oracle实现web分页
- EasyUI datagrid+SpringMVC+MyBatis实现分页查询
- spring boot+mvc+mybatis+netty-sokey.io+html+js实现简单即时通讯聊天系统
- 基于Springmvc+Mybatis+Spring+Freemarker的物理分页插件(超级简单)
- SpringMvc+Mybatis实现一个简单人事管理系统(一)
- springmvc+mybatis+sql server实现简单登录功能【转】
- springmvc+mybatis+sql server实现简单登录功能
- springMVC+MyBatis+Oracle+Web实现增删改查(附带完整案例+数据库数据)
- Maven+Mybatis+Spring+SpringMVC实现分页
- Maven+Mybatis+Spring+SpringMVC实现分页查询(附源代码)
- SpringMVC+Mybatis+Oracle环境下实现ID自增长
- maven+spring+springmvc+mybatis+ajax 框架下实现简单的聊天室
- Maven + Spring MVC+Mybatis + MySQL +AngularJS + Bootstrap 实现简单微博应用(一)环境搭建
- MyBatis+springMVC+easyUI (dataGirl)实现分页(转载)
- bootstrap + mybatis + maven + springmvc 实现分页效果
- springmvc+mybatis+sql server实现简单登录功能【转】