web.xml配置:

<servlet>
<servlet-name>abc</servlet-name>
<servlet-class>test.pageServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>abc</servlet-name>
<url-pattern>/insertstu</url-pattern>
</servlet-mapping>
ConnectionTest.Java
package test;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.Date;
import java.util.List; public class ConnectionTest { public static Statement returnConn() throws SQLException{
// String name="com.mysql.jdbc.Driver";
String url="jdbc:mysql://localhost:3306/page";
String user="root1";
String password="123456";
//加载驱动
try {
Class.forName("com.mysql.jdbc.Driver");
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
//连接数据库
Connection conn=DriverManager.getConnection(url, user, password);
Statement st=conn.createStatement();
return st; } public void closeIo(Connection conn,Statement st) throws SQLException{
conn.close();
st.close();
} }

PageView.java

package test;

import java.util.List;

public class PageView {
private List<Student> records;// 记录
private Long totalrecordnumber;// 总记录数
private Integer startindex;// 第一页
private Integer endindex;// 最后一页
private Integer totalpagenumber;// 总页数
private Integer currentpage;// 当前页
public PageView(List<Student> records, Long totalrecordnumber, int currentpage,
int maximum, int viewperpage)
// 构造函数
{
this.records = records;
this.totalrecordnumber = totalrecordnumber;
this.currentpage = currentpage;
totalpagenumber = (int) (totalrecordnumber % maximum == 0 ? totalrecordnumber
/ maximum
: totalrecordnumber / maximum + 1);//获得总页数
setIndex(currentpage, viewperpage, totalpagenumber);
}
public List<Student> getRecords() {
return records;
}
public Long getTotalrecordnumber() {
return totalrecordnumber;
}
public Integer getStartindex() {
return startindex;
}
public Integer getEndindex() {
return endindex;
}
public Integer getTotalpagenumber() {
return totalpagenumber;
}
public Integer getCurrentpage() {
return currentpage;
}
//获得总页数 显示页数 当前页数 第一页 最后一页
public void setIndex(int currentpage, int viewperpage, int totalpagenumber) {
if (viewperpage >= totalpagenumber) {
startindex = 1;
endindex = totalpagenumber;
} else {
if (currentpage <= viewperpage / 2) {
startindex = 1;
endindex = viewperpage;
} else if ((currentpage + viewperpage / 2) > totalpagenumber) {
startindex = totalpagenumber - viewperpage + 1;
endindex = totalpagenumber;
} else {
startindex = currentpage - (viewperpage - 1) / 2;
endindex = currentpage + viewperpage / 2;
}
}
}
}

Student.java

package test;

import java.util.Date;

public class Student {
private int id;
private String name;
private int age;
private String sex;
private Date birth;
public Student() {
super();
}
public Student(int id, String name, int age, String sex, Date birth) {
super();
this.id = id;
this.name = name;
this.age = age;
this.sex = sex;
this.birth = birth;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public Date getBirth() {
return birth;
}
public void setBirth(Date birth) {
this.birth = birth;
} }

pageServlet.java

package test;

import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.Date;
import java.util.List; import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; public class pageServlet extends HttpServlet {
public static Statement returnConn() throws SQLException{
// String name="com.mysql.jdbc.Driver";
String url="jdbc:mysql://localhost:3306/page";
String user="root1";
String password="123456";
//加载驱动
try {
Class.forName("com.mysql.jdbc.Driver");
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
//连接数据库
Connection conn=DriverManager.getConnection(url, user, password);
Statement st=conn.createStatement();
return st; } public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
//showone(request,response);
try {
showtwo(request,response);
} catch (SQLException e) {
e.printStackTrace();
}
} public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
} public void showone(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException{
try {
Statement st=returnConn();
String sql="select * from student";
ResultSet rs=st.executeQuery(sql);
List<Student> list=new ArrayList<Student>();
while(rs.next()){
int id=rs.getInt("id");
String name=rs.getString("name");
int age=rs.getInt("age");
String sex=rs.getString("sex");
Date birth=rs.getDate("birth");
Student stu=new Student(id,name,age,sex,birth);
list.add(stu);
} //response.sendRedirect("studentlist.jsp");
request.setAttribute("list", list);
request.getRequestDispatcher("studentlist.jsp").forward(request, response); } catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} } public void showtwo(HttpServletRequest request, HttpServletResponse response) throws SQLException, ServletException, IOException{ // 当前是第几页
String currentpageStr = request.getParameter("currentpage") == null ? "1"
: request.getParameter("currentpage");
int currentpage = Integer.parseInt(currentpageStr);
// 每页显示多少条
int maximum = 5;
// 可以显示多少页
int viewperpage = 5; Statement st=returnConn();
String sql="select * from student limit "+ (currentpage - 1) * maximum + "," + maximum;
ResultSet rs=st.executeQuery(sql);
List<Student> list=new ArrayList<Student>();
while(rs.next()){
int id=rs.getInt("id");
String name=rs.getString("name");
int age=rs.getInt("age");
String sex=rs.getString("sex");
Date birth=rs.getDate("birth");
Student stu=new Student(id,name,age,sex,birth);
list.add(stu);
}
String sql2="select * from student";
ResultSet rs2=st.executeQuery(sql2);
int count=0;
while(rs2.next()){
count++;
} long totalrecordnumber=count;
// 将数据都封装到pageView
PageView pageView =new PageView(list, totalrecordnumber, currentpage, maximum, viewperpage);
// PageView<Student> pageView = new PageView<Student>(records,totalrecordnumber, currentpage, maximum, viewperpage);
request.setAttribute("pageView", pageView);
request.setAttribute("list", list);
request.getRequestDispatcher("studentlist.jsp").forward(request, response); }
}

jsp页面代码:

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%@ page import="test.*" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<script type="text/javascript"> function topage(currentpage) {
var form = document.forms[0];
form.currentpage.value = currentpage;
form.submit();
}
</script> </head> <body>
<form>
<input type="hidden" name="currentpage" />
<table align="center" style="width: 60%;" border="1">
<tr>
<th>学生编号</th>
<th>学生姓名</th>
<th>学生年龄</th>
<th>学生性别</th>
<th>学生生日</th>
</tr>
<c:forEach items="${requestScope.list}" var="list">
<tr>
<td>${list.id }</td>
<td>${list.name }</td>
<td>${list.age }</td>
<td>${list.sex }</td>
<td>${list.birth}</td> </tr>
</c:forEach> </table>
<div align="right" style="width: 80%">
<c:forEach begin="${pageView.startindex}" end="${pageView.endindex}"
var="wp">
<c:if test="${pageView.currentpage==wp}">
<b>[${wp}]</b>
</c:if>
<c:if test="${pageView.currentpage!=wp}">
<a href="javascript:topage('${wp}')">[${wp}]</a>
</c:if>
</c:forEach>
总共${pageView.totalrecordnumber}页
</div>
</form> </body>
</html>

java+jsp+servlet实现分页的更多相关文章

  1. 从0开始学Java——JSP&Servlet——Tomcat和Apache的区别

    从<JSP & Servlet 学习笔记>的第一章,了解到web容器:“Web容器是Servlet/jsp唯一认得的http服务器”. 在Java中,容器的类型有多种,这里要说的是 ...

  2. 从0开始学Java——JSP&Servlet——HttpServletRequest相关的几个路径信息

    在HttpServletRequest中有几个获取路径的接口:getRequestURI/getContextPath/getServletPath/getPathInfo 这些接口互相之间有什么区别 ...

  3. python&&Java&&jsp+servlet连接数据库报错收藏(sql server,mysql)

    写在最前面:sql server和mysql 是不同的东西... 我在完成java连接数据库的时候把这俩当成一个东西,结果下的mysql的jar包. 但自己的sql是server.. 然后尝试用 py ...

  4. 从0开始学java——JSP&Servlet——web容器搜索class的路径顺序

    在web应用程序如果要用到某个类,会按照如下的顺序来搜索: 1)在WEB-INF/classes目录下搜索: 2)如果该目录下没有,则会到WEB-INF/lib目录下的jar文件中搜索: 3)如果还没 ...

  5. 从0开始学Java——JSP&Servlet——如何部署web应用程序

    web容器要求应用程序部署时,需要像下面这样组织其目录结构: 手动去创建这样的目录结构还是挺麻烦的,所幸我们有开发工具,所以可以像下面这样来部署一个web项目. 1)确认程序代码已经完成: 2)在ec ...

  6. 从0开始学Java——JSP&Servlet——如何在Eclipse中配置Web容器为tomcat

    windows- >Preferences -> Server->runtime Envirement ->Add 点击下一步,然后按照如下设置:  

  7. 招新系统(jsp+servlet,实现简略前端网页注册登录+后台增删改查,分学生和管理员,Java语言,mysql数据库连接,tomcat服务器)

    生活不只是眼前的苟且,还有诗和远方. 架构说明: 要求是采用MVC模式,所以分了下面的几个包,但是由于是第一次写,可能分的也不是很清楚: 这个是后台部分的架构: 这个是前端的的展示: (那个StuLo ...

  8. jsp+servlet分页查询

    分页查询 减少服务器内存开销 提高用户体验 效果图 思绪图 分页显示Bean文件代码 package cn.ytmj.findlist.domain; import java.util.List; / ...

  9. Java面试题精选(三) JSP/Servlet Java面试逻辑题

    --   JSP/Servlet  Java面试逻辑题   --     很显然,Servlet/JSP的WEB前端动态制作的重要性比HTML/CSS/JS的价值高很多,但我们都知道他们都是建立在HT ...

随机推荐

  1. 纯css3 3D图片立方体旋转动画特效

    纯css3 3D立方体模块,鼠标触碰,模块炸开,大立方体中套小立方体 效果展示 手机扫描二维码体验效果: 效果图如下: 源码下载:http://hovertree.com/h/bjaf/0qmul8g ...

  2. Android将应用调试log信息保存在SD卡

    转载:http://blog.csdn.net/way_ping_li/article/details/8487866 把自己应用的调试信息写入到SD卡中. package com.sdmc.hote ...

  3. ViewPager之Fragment页面切换

    一.概述 ViewPager是android-support-v4中提供的类,它是一个容器类,常用于页面之间的切换. 继上篇文章<ViewPager之引导页>之后,本文主要介绍ViewPa ...

  4. Android开发案例 - 自定义虚拟键盘

    所有包含IM功能的App(如微信, 微博, QQ, 支付宝等)都提供了Emoji表情之类的虚拟键盘,  如下图:    本文只着重介绍如何实现输入法键盘和自定义虚拟键盘的流畅切换, 而不介绍如何实现虚 ...

  5. Struts2初始(一)

    1.过滤器:org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter位置:在struts2的核心包struts2-co ...

  6. 【代码笔记】iOS-获得现在的日期

    一,代码. - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, ...

  7. Highchart插件下载与安装

    提供完整的 Highcharts 资源包,包含实例文件.所有的 js 压缩版及源码.导出服务器文件等. 1.资源包的使用: 2.开放的CDN:http://img.hcharts.cn/ 二.High ...

  8. linux php编译安装

    1.下载php安装包 http://cn2.php.net/get/php-5.5.36.tar.gz/from/this/mirror 默认情况下Nginx和PHP他俩之间是一点感觉没有的.Apac ...

  9. Python 代码风格

    1 原则 在开始讨论Python社区所采用的具体标准或是由其他人推荐的建议之前,考虑一些总体原则非常重要. 请记住可读性标准的目标是提升可读性.这些规则存在的目的就是为了帮助人读写代码,而不是相反. ...

  10. Mac卸载MySQL

    打开终端输入以下指令即可 sudo rm -rf /Library/StartupItems/MySQLCOM sudo rm -rf /Library/PreferencePanes/My* rm ...