这是看韩顺平老师的servlet视频,自己动手写的,楼主看韩顺平老师的servlet是2006制作的,用的是sql server数据库,自己又用的是oracle数据库,所以怕有的同学遇到同样的问题,不知道去哪参考oracle,所以想写一写oracle版本的servler分页技术!在写代码之前,首先要弄明白分页算法:

四个变量,int pageSize:每页显示多少条记录.int pageNow:希望显示第几页.int pageCount:一共有多少页,int rowCount:一共有多少条记录! 其中,pageSize是指定的,pageNow是用户或者默认的,就是现在显示第几条,rowCount是从表中查询得到的,pageCount是表示页数,有多少页,需要计算,计算的算法是:

if(rowCount%pageSize == 0) {
   pageCount = rowCount/pageSize;
} else {
   pageCount = rowCount/pageSize + 1;
}

从数据库中查询出记录总数的slq语句:

select count(*) from users

分页时候遇到一个问题,如果第十一条数据到第二十条数据中,缺少一条,也就是说,记录顺序不是连续的,是断开的,怎么查询出连续的记录?sql语句如下:

rs = st.executeQuery("select * from(select t.*, rownum rn from(select * from users order by userid) t where rownum <=" + pageNow*pageSize+ ") where rn >=" + ((pageNow-1)*pageSize+1) +"");

在不断的调试代码过程中,还顺便引入了css和加入动态图片,效果如图,

java代码:

package cn.com.shizongger;

import javax.servlet.*;
import javax.servlet.http.*;
import java.sql.*;
import java.io.*;

public class FenYe extends HttpServlet {

	@Override
	protected void doGet(HttpServletRequest req, HttpServletResponse res){
		int pageSize = 5;	//每页显示5条记录
		int pageNow = 1;	//希望显示第几页,默认第一页
		int pageCount = 0; //总数页,用总记录数除每页显示多少条记录
		int rowCount = 0; //总记录数

		//从数据库中计算出总记录数
		Connection ct = null;
		Statement st = null;
		ResultSet rs = null;

		res.setContentType("text/html;charset=gbk");

		//从url中获取要现实的页数
		String pageStr = req.getParameter("pageNow");

		try{
			PrintWriter out = res.getWriter();

			//1.加载驱动
			Class.forName("oracle.jdbc.driver.OracleDriver");
			//2.得到链接
			ct = DriverManager.getConnection("jdbc:oracle:thin:@127.0.0.1:1521:orcl",
						"scott", "Shizongger_5476");
			//获取状态
			st = ct.createStatement();

			//从数据库中获取总记录数
			rs = st.executeQuery("select count(*) from users");
			if(rs.next()) {
				rowCount = rs.getInt(1);
				if(rowCount%pageSize == 0) {
					pageCount = rowCount/pageSize;
				} else {
					pageCount = rowCount/pageSize + 1;
				}
			}

			if(pageStr != null) {
				//从字符串中转整型
				pageNow = Integer.parseInt(pageStr);
				if(pageNow > pageCount) {
					pageNow = pageCount;
				} else if(pageNow < 1) {
					pageNow = 1;
				}
			}

			//从数据库中查询记录
			//rs = st.executeQuery("select * from users where userid between " + ((pageNow-1)*pageSize+1)
			//			+ " and " + pageNow*pageSize + " order by userid");

			rs = st.executeQuery("select * from(select t.*, rownum rn from(select * from users order by userid) t where rownum <=" + pageNow*pageSize+ ") where rn >=" + ((pageNow-1)*pageSize+1) +"");
System.out.println(((pageNow-1)*pageSize+1) + " " + (pageNow*pageSize));
			out.println("<html>\n<head>");
			//为页面添加css样式
			out.println("<link rel=\"stylesheet\" type=\"text/css\" href=\"mycss.css\" />");
			out.println("</head>\n<body background=hudie.gif><center>");
			out.println("<h1>恭喜,你已经成功登录系统</h1>");
			out.println("总记录:" + rowCount);
			out.println("<table>");
			out.println("<tr><th>用户ID</th><th>用户名</th><th>密码</th><th>Email</th><th>等级</th></tr>");
			while(rs.next()) {
				out.println("<tr>");
				out.println("<td>" + rs.getInt(1) + "</td>");
				out.println("<td>" + rs.getString(2) + "</td>");
				out.println("<td>" + rs.getString(3) + "</td>");
				out.println("<td>" + rs.getString(4) + "</td>");
				out.println("<td>" + rs.getInt(5) + "</td>");
				out.println("</tr>");
			}
			out.println("</table>");

			//显示首页
			out.println("<a href=fenye?pageNow=" + 1 + " >" + "首页" + "</a>");
			//显示上一页
			out.println("<a href=fenye?pageNow=" + (pageNow-1) + " >" + "上一页" + "</a>");

			//显示页数
			int start = (int)(pageNow/10)*10 + 1;
			for(int i = start; i <= start+9; i++) {
				if(i >= 1 && i <= pageCount) {
					if(i != pageNow) {
						out.println("<a href=fenye?pageNow=" + i + " >" + i + "</a>");
					} else {
						out.println("<a class=style1 href=fenye?pageNow=" + i + " >" + i + "</a>");
					}
				}
			}

			//显示上一页
			out.println("<a href=fenye?pageNow=" + (pageNow+1) + " >" + "下一页" + "</a>");
			//尾页
			out.println("<a href=fenye?pageNow=" + pageCount + " >" + "尾页" + "</a>");

			out.println("</center>\n</body>\n</html>");

		} catch(Exception ex) {
			ex.printStackTrace();
		}
	}

	@Override
	protected void doPost(HttpServletRequest req, HttpServletResponse res) {
		this.doGet(req, res);
	}
}

外部css代码:

table {
	width:550px;
}
a:link{
	text-decoration:none;
	color:blue;
}
a:visited{
	text-decoration:line-through;
	color:blue;
}
a:hover{
	text-decoration:underline;
	color:red;
}
a:active{
	text-decoration:overline;
	color:red;
}
h1{
	font-size:24px;
	color:red;
}
.style1{
	font-size:22px;
}

Servlet分页技术的更多相关文章

  1. Servlet课程0426(八)Servlet分页技术

    Welcome.java //登录界面 package com.tsinghua; import javax.servlet.http.*; import java.io.*; import java ...

  2. jsp-------------之分页技术(一)

    jsp分页技术之: 如下图:百度的喵 看上图中卡哇伊的小苗的爪子下面的数字,就是分页啦!那我们如何做出这样一个效果呢? 下面我们来逐一分解: jsp分页技术一 :  (算法) /* int pageS ...

  3. Javaweb 第15天 web练习和分页技术

    第15天 web练习和分页技术 复习day14内容: 学习新技术的思路? 分析功能的思路? 使用queryRunner操作数据库的步骤? ResultSetHandler接口常用实现类(三个重点)? ...

  4. 改进Spring中的分页技术

    Spring中有一个PagedListHolder,能够实现分页. 但此类有几个缺点: 1. 使用此类的代码比較繁琐 2. 此类存放的数据源是全部的记录集,即对于记录数为1000条的数据,即使我们仅仅 ...

  5. JAVAEE之-----MySQL分页技术(带搜索)

    需求: 为什么须要採用分页技术呢?在数据库中我们查询数据的时候,须要将数据返回到显示页面.数据库中含有大量数据,所有显示在一个页面过于太多,所以我们须要採用分页技术.每一页显示不同数据. 主要解决这个 ...

  6. Mysql学习总结(32)——MySQL分页技术详解

    1.什么是数据分页:数据分页就是将很多条记录像书本一样分页,每页显示多少行记录: 2.为什么要数据分页:当我们进行sql语句查询时,假如数据有成千上万行记录,如果在同一个页面去显示,那这个页面得有多大 ...

  7. tp中使用分页技术

    1 public function showList() { $m_ld = D ( 'guangxi_ld' ); $page = I ( 'get.p', 1 ); // 在配置中获取分页值 $p ...

  8. 分页技术之PageDataSource类

    之前给大家介绍了分页技术之Gridview控件,今天给大家介绍另外一种分页技术,采用PageDataSource类 + Repeater控件来实现. 前台只需要拖出一个Repeater控件来绑定要显示 ...

  9. 分页技术之GridView控件

    GridView控件实现分页技术 第一步:设置GridView控件的属性,跟分页相关的属性设置如下: AllowPaging="true":允许分页, PageSize=" ...

随机推荐

  1. JS去掉首尾空格 简单方法大全(原生正则jquery)

    JS去掉首尾空格 简单方法大全 var osfipin= ' http://www.cnblogs.com/osfipin/ '; //去除首尾空格 osfipin.replace(/(^\s*)|( ...

  2. 服务 {49A27252-A326-4EF1-B698-6EBC7068833C} 的计时器作业 id {573BE459-DF82-481C-84BD-CA14D287450B} 配置刷新的上一个实例仍在运行,因此将跳过当前的实例。请考虑增加作业之间的时间间隔。

    在SharePoint2007的错误日志中发现大量如下错误: 07/02/2013 16:17:25.99     OWSTIMER.EXE (0x0958)     0x097C    Window ...

  3. HttpClient示例

    <%@page import="com.sun.xml.ws.client.BindingProviderProperties"%> <%@page conten ...

  4. 通过终端编译链接运行C文件

    1.创建c文件 touch demo.c 2.编辑c代码 3.编译(预编译.检查语法.编译).链接 3.1.指令:cc  -c  demo.c 正常情况下,会生成一个demo.o的二进制文件(即:目标 ...

  5. 关于iOS和OS X废弃的API知识点

    今天在查看苹果接口文档时,突然对于接口的声明知识点比较感兴趣,再网络找到下面这个比较不错的文章,记录一下并分享: 如你所知,已废弃(Deprecated)的API指的是那些已经过时的并且在将来某个时间 ...

  6. join()方法

    1.现在有T1.T2.T3三个线程,你怎样保证T2在T1执行完后执行,T3在T2执行完后执行? package com.mianshi.easy; class JoinDemo implements ...

  7. WWDC 2013 Session笔记 - UIKit Dynamics入门

    本文涉及到的WWDC2013 Session有 1.Session 206 Getting Started with UIKit Dynamics 2.Session 221 Advanced Tec ...

  8. 学习Coding-iOS开源项目日志(四)

    Hello,大家好,好久没写博客了,今天再次来研究研究Coding源码,久违了. 前 言:作为初级程序员,想要提高自己的水平,其中一个有效的学习方法就是学习别人好的项目.本篇开始会陆续更新本人对git ...

  9. thinkphp 创建子应用

    1 根目录建立 文件名 a 2 a 下建立index.php define('APP_NAME', 'a');define('APP_PATH', './a');define('RUNTIME_PAT ...

  10. jQuery和ExtJS的timeOut超时问题和event事件处理问题

    对jQuery来说,超时可以直接设置timeout参数,并在error事件中捕获第二个参数,如果是“timeout”则表明捕获了超时事件,非常清楚. 例子: $.ajax({         type ...