介绍几个java分页
介绍几种分页方法还有:
“首页 上一页 1 2 3 4 5 6 7 8 9 下一页 末页 第 页”
这个Java是否可以做,可以的话,说的详细点,最好有代码,谢谢了
[解决办法]
能做
就是html写出来就好了
代码弄个Page类,每次查询(页数-1)*每页条数+1到页数*每页条数个
[解决办法]
分页的方法有很多,但是他们实现的思想也有差别。。
这里有个例子,你可以参考下。。。经测试可用。http://download.csdn.net/source/854446
[解决办法]
可以做,分页逻辑可以用jdbc的sql分页语句,也可以直接用hibernate进行分页,表现形式,写个pageBar,需要用的时候导入就好了
[解决办法]
<html>
<head>
<script language="javaScript">
<!--
function Jumping()
{
document.PageForm.submit();
}
function gotoPage(pagenum)
{
document.PageForm.jumpPage.value=pagenum;
document.PageForm.submit();
}
//-->
</script>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Insert title here </title>
</head>
<body>
每页 <%=pageCtl.getRowsPerPage()%>行
共 <%=pageCtl.getMaxRowCount()%>行
第 <%=pageCtl.getCurPage()%>页
共 <%=pageCtl.getMaxPage()%>页
<br>
<%if(pageCtl.getCurPage()==1){out.print("首页 上一页");} else{ %>
<A href="javascript:gotoPage(1)">首页 </A>
<A href="javascript:gotoPage( <%=pageCtl.getCurPage()-1%>)">上一页 </A>
<%} %>
<%if(pageCtl.getCurPage()==pageCtl.getMaxPage()){out.print("下一页 尾页");} else{ %>
<A href="javascript:gotoPage( <%=pageCtl.getCurPage()+1%>)">下一页 </A>
<A href="javascript:gotoPage( <%=pageCtl.getMaxPage()%>)">尾页 </A>
<%} %>
转到第 <select name="jumpPage" onchange="Jumping()">
<%
for(int i=1;i <=pageCtl.getMaxPage();i++)
{
if(i==pageCtl.getCurPage()){
%>
<option selected value= <%=i%>> <%=i%> </option>
<%}else{ %>
<option value= <%=i%>> <%=i%> </option>
<% }
}
%>
</select>页
</body>
</html>
分页主页面
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<jsp:useBean id="pageCtl" class="page.PageBean" scope="request"> </jsp:useBean>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<%@page import="java.util.Vector"%>
<%@page import="java.util.Enumeration"%> <html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Insert title here </title>
</head>
<body>
<table border=1>
<%
java.util.Vector v=pageCtl.getResult();
java.util.Enumeration e = v.elements();
while(e.hasMoreElements())
{
Object[] obj = (Object[])e.nextElement();
%>
<tr>
<td align="center" width="50%"> <%=obj[0]%> </td>
<td align="center" width="50%"> <%=obj[1]%> </td>
</tr>
<%} %>
</table>
<%if(pageCtl.getMaxPage()!=1){ %>
<form id="PageForm" name="PageForm" action="/LMSTEST/ContactServlet" method="get">
<%@ include file="/pageman.jsp" %> </form>
<%} %>
</body>
</html>
分页程序ContactServlet.java
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import page.ContactBean;
import page.PageBean;
/**
* Servlet implementation class ContactServlet
*/
public class ContactServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
/**
* Default constructor.
*/
public ContactServlet() {
// TODO Auto-generated constructor stub
}
/**
* @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
*/
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
request.setCharacterEncoding("utf-8");
response.setContentType("text/html");
response.setCharacterEncoding("utf-8");
PrintWriter out = response.getWriter();
try {
ContactBean contact = new ContactBean();
PageBean pageCtl = contact.listData((String) request
.getParameter("jumpPage"));
System.out.print(pageCtl.getMaxPage());
request.setAttribute("pageCtl", pageCtl);
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
}
RequestDispatcher dis = request.getRequestDispatcher("/contact.jsp");
dis.forward(request, response);
}
/**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
doGet(request, response);
}
}
ContactBean.java
package page;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Vector;
import com.neusoft.njpro.Test;
public class ContactBean {
private Connection conn;
Vector v;
/**
* 创建数据库一个连接
* 初始化一个vector
*/
public ContactBean()
{
Test test = new Test();
conn = test.getCon();
v = new Vector();
}
/**
* @return 要查询的记录数
* @throws SQLException
*/
public int getAvailableCount() throws SQLException
{
int ret = 0;
Statement stmt = conn.createStatement();
ResultSet rset = stmt.executeQuery("select count(*) from procedure_test");
while(rset.next())
{
ret = rset.getInt(1);
}
return ret;
}
/**
* @param page获取指定页面的数据,并且封装在PageBean中返回
* @return
* @throws Exception
*/
public PageBean listData(String page) throws Exception
{
try {
PageBean pageBean = new PageBean(this);
int pageNum = Integer.parseInt(page);
Statement stmt = conn.createStatement();
String strSql = "select * from (select rownumber() over(order by log_time) as rn,procedure_test.* from procedure_test) as t where t.rn between "
+ (pageNum * pageBean.rowsPerPage-pageBean.rowsPerPage+1)
+ " and "+ pageNum * pageBean.rowsPerPage;
ResultSet rset = stmt.executeQuery(strSql);
while (rset.next()) {
Object[] obj = new Object[2];
obj[0] = rset.getString(3);
obj[1] = rset.getObject(4);
v.add(obj);
}
rset.close();
stmt.close();
pageBean.curPage = pageNum;
pageBean.data = v;
return pageBean;
} catch (Exception e) {
e.printStackTrace();
throw e;
// TODO: handle exception
}
}
public Vector getResult()
{
return v;
}
}
PageBean.java
package page;
import java.sql.SQLException;
import java.util.Vector;
public class PageBean {
public int getCurPage() {
return curPage;
}
public void setCurPage(int curPage) {
this.curPage = curPage;
}
public int getMaxPage() {
return maxPage;
}
public void setMaxPage(int maxPage) {
this.maxPage = maxPage;
}
public int getMaxRowCount() {
return maxRowCount;
}
public void setMaxRowCount(int maxRowCount) {
this.maxRowCount = maxRowCount;
}
public int getRowsPerPage() {
return rowsPerPage;
}
public void setRowsPerPage(int rowsPerPage) {
this.rowsPerPage = rowsPerPage;
}
public java.util.Vector getData() {
return data;
}
public void setData(java.util.Vector data) {
this.data = data;
}
public int curPage; //当前是第几页
public int maxPage; //一共多少页
public int maxRowCount; //一共是多少行
public int rowsPerPage = 5; //每页多少行
public java.util.Vector data; //本页中的资料
public PageBean()
{
}
public void countMaxPage() //根据总行数计算总页数
{
if(this.maxRowCount%this.rowsPerPage==0)
{
this.maxPage = this.maxRowCount/this.rowsPerPage;
}
else
{
this.maxPage = this.maxRowCount/this.rowsPerPage+1;
}
}
public Vector getResult()
{
return this.data;
}
public PageBean(ContactBean contact) throws SQLException
{
this.maxRowCount = contact.getAvailableCount(); //得到总行数
this.data = contact.getResult(); //得到要显示于本页的资料
this.countMaxPage();
}
}
[解决办法]
servlet代码也没有搞上来,不过学这门的应该看得懂!
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ page language="java" import="java.util.*" pageEncoding="GBK"%>
<html>
<head>
<script type="text/javascript">
function goto(){
var page=document.getElementById("pp").value;
var url=null;
if(page==""||page==null){
alert("不能为空");
return;
}else{
url="PageServlet?page="+page;
}
location.href=url;
}
</script>
<title>分页</title>
<link rel="stylesheet" href="css/css.css" type="text/css"></link></head>
<body>
<form action="PageServlet" name="pageForm">
<table>
<c:forEach items="${requestScope.list}" var="page">
<c:if test="${page!=null}">
<tr>
<td>${page.num }</td>
</tr>
</c:if>
</c:forEach>
</table>
</from>
<a href="PageServlet?page=1">首页</a> 总记录数/总页数 ${requestScope.sumCount}/${requestScope.sumPage} 您现在位于第${requestScope.page }页
每页显示 5 条记录
<a href="PageServlet?page=1">[1]</a>
<c:if test="${requestScope.page!=1}">
<c:choose>
<c:when test="${requestScope.page<=5}">
<c:forEach var="i" begin="2" end="${requestScope.page}">
<a href="PageServlet?page=${i}"> [${i }]</a>
</c:forEach>
</c:when>
<c:otherwise>
...
<c:forEach var="i" begin="${requestScope.page-3}"
end="${requestScope.page}">
<a href="PageServlet?page=${i}">[${i}]</a>
</c:forEach>
</c:otherwise>
</c:choose>
<c:choose>
<c:when test="${requestScope.page>=requestScope.sumPage-4
|| requestScope.sumPage-4<=0}">
<c:forEach var="i" begin="${requestScope.page+1}"
end="${requestScope.sumPage}">
<a href="PageServlet?page=${i}">[${i }]</a>
</c:forEach>
</c:when>
<c:otherwise>
<c:forEach var="i" begin="${requestScope.page+1}"
end="${requestScope.page+3}">
<a href="PageServlet?page=${i}">[${i }]</a>
</c:forEach>
...
<a href="PageServlet?page=${requestScope.sumPage}">
[${requestScope.sumPage}]</a>
</c:otherwise>
</c:choose>
</c:if>
<a href="PageServlet?page=${requestScope.page-1 }">上一页</a>
<a href="PageServlet?page=${requestScope.page+1 }">下一页</a>
<a href="PageServlet?page=${requestScope.sumPage }">尾页</a>
<input type="button" name="Submit" value="转到" onClick="javascript:goto()">
<input type="text" id="pp" name="pp" size=4/>页
</body>
</html>
[解决办法]
<%@ page language="java" import="java.sql.*,java.util.*" %>
<%@ page contentType="text/HTML;charset=GB2312"%>
<jsp:useBean id="dbBean" scope="page" class="mybean.dbConnect" />
<%
int pagesize=2;//每页显示的数据数量
//下边两个变量是把动态生成的部分集中在一起放入页面
//这样做的好处是当修改页面时就可以直接用DreamWeaver编辑了
StringBuffer userInfo=new StringBuffer();
StringBuffer pageInfo=new StringBuffer();
//使用JavaBean执行数据库操作
ResultSet rs=dbBean.executeQuery("select * from userInfo");
//获得需要显示的页,如果接受不到参数,默认是第1页
String paramPage=request.getParameter("page");
int currentPage=1;
try{
currentPage=Integer.parseInt(paramPage);
}catch(Exception e){
currentPage=1;
}
rs.last(); //把指针置底
int totaluser=rs.getRow(); //获得结果数量
//计算出总页数
int pagecount=(int)Math.ceil((float)totaluser/(float)pagesize);
int i=1;
rs.absolute((currentPage-1) * pagesize + 1); //把指针放到要显示的第一个数据
//把结果放进变量userInfo
while(i<=pagesize && !rs.isAfterLast()){
userInfo.append("<tr bgcolor=#ffffff>\n");
userInfo.append("<td align=center>"+((currentPage-1)*pagesize+i)+"</td>");
userInfo.append("<td align=center>"+rs.getString("username")+"</td>");
userInfo.append("<td>"+rs.getString("phone")+"</td>");
userInfo.append("<td>"+rs.getString("email")+"</td>");
userInfo.append("</tr>");
if(!rs.next()) //当到达最后一个记录时,退出循环
break;
i++;
}
//把显示翻页的字段放进变量pageInfo
pageInfo.append("第"+currentPage+"页 共"+pagecount+"页, 共"+totaluser+"个用户 ");
if(currentPage>1) //在当前页大于1时有向前翻页的连接,否则没有
pageInfo.append(" <a href='usebeanuserlist.jsp?page="+(currentPage-1)+"'><< 上一页</a>");
else
pageInfo.append("<< 上一页");
if(currentPage<pagecount) //在当前页小于总页数时有向前翻页的连接,否则没有
pageInfo.append(" <a href='usebeanuserlist.jsp?page="+(currentPage+1)+"'>下一页 >></a>");
else
pageInfo.append("下一页 >>");
%>
<html>
<head>
</head>
<body>
<table width="80%" border="0" align="center" cellpadding=5 cellspacing=1 bgcolor=#000000>
<tr align="center" bgcolor=#cccccc>
<td width="12%">编号</td>
<td width="23%">真实姓名</td>
<td width="25%">电话号码</a></td>
<td width="40%">邮件地址</td> </tr>
<%=userInfo%>
</table>
<table width="80%" border="0" align="center">
<tr>
<td align=right><%=pageInfo%></td>
</tr>
</table>
</body>
</html>
[解决办法]
实现的分页主要有两种,一种是客户端分页(假分页),另一种是服务器端分页,所谓客户端分页就是用一条SQL语句select * from table,将所有记录都取出来,然后再客户端知道了是第几页后用rs.absulte(pagesize*currentPage)定位到某一条记录,从而实现分页。服务器端分页是指将要显示的页码发送到服务器端,服务器端计算取出的记录是从哪一条到哪一条,然后构造特定的SQL语句,譬如MYSQL可以用LIMIT实现从哪一条记录到哪一条记录,ACCESS和MSSQL可以用TOP实现去除前多少条,然后再嵌套一个TOP实现取出特定条数的记录.一般采用服务器端分页,因为客户端分页每次都得查询整个数据库,效率较低。
[解决办法]
用自定交标签 写
至于数据库 楼上写的都不错
1,写java 文件
public class PageJstl extends SimpleTagSupport {
private PageBean myPageBean;
private String queryType;
public PageBean getMyPageBean() {
return myPageBean;
}
public void setMyPageBean(PageBean myPageBean) {
this.myPageBean = myPageBean;
}
public void doTag() throws JspException, IOException {
// TODO Auto-generated method stub
JspWriter out = this.getJspContext().getOut();
out.print("<TABLE cellSpacing=1> <TBODY> <TR>");
out.print("<TD><a href="+queryType+".do?type="+myPageBean.getType()+"><IMG src=\"file/2arrow_l_off.gif\" border=0></a></TD>");
if(myPageBean.getPagecode()>1)
out.print("<TD><a href="+queryType+".do?type="+myPageBean.getType()+"&pagecode="+(myPageBean.getPagecode()-1)+"><IMG src=\"file/1arrow_l_off.gif\" border=0></a></TD>");
else
out.print("<TD><IMG src=\"file/1arrow_l_off.gif\" border=0></TD>");
if(myPageBean.getPagecode()<myPageBean.getAllpage())
out.print("<TD><a href="+queryType+".do?type="+myPageBean.getType()+"&pagecode="+(myPageBean.getPagecode()+1)+"><IMG src=\"file/1arrow_r_off.gif\" border=0></a></TD>");
else
out.print("<TD><IMG src=\"file/1arrow_r_off.gif\" border=0></TD>");
out.print("<TD><a href="+queryType+".do?type="+myPageBean.getType()+"&pagecode="+myPageBean.getAllpage()+"><IMG src=\"file/2arrow_r_off.gif\" border=0></a></TD>");
out.print("</TR></TBODY></TABLE>");
out.flush();
}
public String getQueryType() {
return queryType;
}
public void setQueryType(String queryType) {
this.queryType = queryType;
}
}
2, .tld 文件
<?xml version="1.0" encoding="UTF-8" ?>
<taglib xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-jsptaglibrary_2_0.xsd"
version="2.0">
<display-name>JSTL page</display-name>
<tlib-version>1.0</tlib-version>
<short-name>Fpage</short-name>
<uri>http://qingruxu.net/fpage</uri>
<tag>
<name>mypage</name>
<tag-class>jstl.PageJstl</tag-class>
<body-content>empty</body-content>
<attribute>
<name>myPageBean</name>
<required>true</required>
<rtexprvalue>true</rtexprvalue>
<type>service.PageBean</type>
</attribute>
<attribute>
<name>queryType</name>
<required>true</required>
<rtexprvalue>true</rtexprvalue>
</attribute>
</tag>
</taglib>
3,在页面上调用
先引入 <%@ taglib prefix="Fpage" uri="http://qingruxu.net/fpage" %>
<Fpage:mypage myPageBean="${pageBean}" queryType="chenshanAction"/>
${pageBean} 为数据集合 我放的是一个java类
如下
public class PageBean {
private int pagesize;//页大小
private int pagecode;//当前页
private int allcount;//所有记录数
private int allpage;//总页数
private int type;//type 值
private String reValue;//标题
private List data=new ArrayList();
。。。