标签:handler int value ges osal jdbc .com var 技术分享
进行网页开发,那么就少不了分页查询。分页查询在mysql中是最方便的,使用mysql的关键字LIMIT(mysql独有),即可进行分页查询。如下是mysql的分页查询的sql语句:
SELECT * FROM hero LIMIT ?, ? # 第一个?表示的是从那条数据开始查询 # 第二个?表示的是每次查询的数据的条数
而在Oracle中也有一个方言,专门用来Oracle数据库的分页查询,关键字为:ROWNUM 和 row_number()
下面使用mysql演示分页:
jsp页面:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>分页操作</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<link href="table.css" rel="stylesheet" type="text/css">
</head>
<body>
<div align="center"><h1 style="color: #000000; align:center">演示分页查询</h1></div>
<table cellpadding="1" border="1" cellspacing="0" bordercolor="black" align="center">
<tr class="tab-2">
<td>编号</td>
<td>英雄名字</td>
<td>英雄Job</td>
<td>英雄上司编号</td>
<td>英雄雇佣日期</td>
<td>英雄薪水</td>
<td>英雄奖金</td>
<td>英雄类型</td>
</tr>
<%-- <c:if test="${null ne heros }"> --%>
<c:forEach items="${heros }" var="hero">
<tr class="tab-5">
<td>${hero.herono }</td>
<td>${hero.heroname }</td>
<td>${hero.herojob }</td>
<td>${hero.heromgr }</td>
<td>${hero.herohiredate }</td>
<td>${hero.herosal }</td>
<td>${hero.herocomm }</td>
<td>${hero.herotype }</td>
</tr>
</c:forEach>
<%-- </c:if> --%>
</table><br/><br/>
<div align="center">
<c:if test="${num-1 > 0 }">
<a href="<c:url value=‘/SplitServlet‘/>?method=splitenum&num=${num-1}">上一页</a>
<a href="<c:url value=‘/SplitServlet‘/>?method=splitenum&num=${num-1}">第${num-1 }页</a>
</c:if>
<a href="<c:url value=‘/SplitServlet‘/>?method=splitenum&num=${num}">第${num }页</a>
<c:if test="${num+1 <= all }">
<a href="<c:url value=‘/SplitServlet‘/>?method=splitenum&num=${num+1}">第${num+1 }页</a>
<a href="<c:url value=‘/SplitServlet‘/>?method=splitenum&num=${num+1}">下一页</a>
</c:if>
<a href="<c:url value=‘/SplitServlet‘/>?method=splitenum&num=1">刷新</a>
<font color="red" size="5px">总共 ${all } 页</font>
</div>
</body>
</html>
dao:
package cn.geore.splitpage;
import java.sql.SQLException;
import java.util.List;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import org.apache.commons.dbutils.handlers.ScalarHandler;
import priv.geore.toolutils.jdbc.FirmQueRunner;
public class SplitPageDao {
QueryRunner runner = new FirmQueRunner();
/**
* 查询每页的数据
* @param page
* @param count
* @return
* @throws SQLException
*/
public List<Hero> findHero(int page, int count) throws SQLException {
String sql = "SELECT * FROM hero LIMIT ?,?";
Object[] params = {(page-1)*4,count};
return (List<Hero>) runner.query(sql, new BeanListHandler<Hero>(Hero.class), params);
}
/**
* 查询页数
* @return
* @throws SQLException
*/
public Number count() throws SQLException {
String sql = "SELECT count(*) FROM hero";
return runner.query(sql, new ScalarHandler<Number>());
}
}
servlet:
package cn.geore.splitpage;
import java.io.IOException;
import java.sql.SQLException;
import java.util.List;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import priv.geore.toolutils.web.FirmHttpServlet;
public class SplitServlet extends FirmHttpServlet {
SplitPageDao dao = new SplitPageDao();
/**
* 分页查找数据
* @param request
* @param response
* @return
* @throws ServletException
* @throws IOException
*/
public String splitenum(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
int num = Integer.valueOf(request.getParameter("num"));
List<Hero> heros = null;
int all = 0;
try {
heros = dao.findHero(num, 4);
all = (int) Math.floor(dao.count().intValue() / 4.0);
} catch (SQLException e) {
throw new RuntimeException(e);
}
request.setAttribute("heros", heros);
request.setAttribute("num", num);
request.setAttribute("all", all);
return "f:/index.jsp";
}
}
运行截图:



标签:handler int value ges osal jdbc .com var 技术分享
原文地址:http://www.cnblogs.com/geore/p/7392248.html