java+jsp+servlet实现分页
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实现分页的更多相关文章
- 从0开始学Java——JSP&Servlet——Tomcat和Apache的区别
从<JSP & Servlet 学习笔记>的第一章,了解到web容器:“Web容器是Servlet/jsp唯一认得的http服务器”. 在Java中,容器的类型有多种,这里要说的是 ...
- 从0开始学Java——JSP&Servlet——HttpServletRequest相关的几个路径信息
在HttpServletRequest中有几个获取路径的接口:getRequestURI/getContextPath/getServletPath/getPathInfo 这些接口互相之间有什么区别 ...
- python&&Java&&jsp+servlet连接数据库报错收藏(sql server,mysql)
写在最前面:sql server和mysql 是不同的东西... 我在完成java连接数据库的时候把这俩当成一个东西,结果下的mysql的jar包. 但自己的sql是server.. 然后尝试用 py ...
- 从0开始学java——JSP&Servlet——web容器搜索class的路径顺序
在web应用程序如果要用到某个类,会按照如下的顺序来搜索: 1)在WEB-INF/classes目录下搜索: 2)如果该目录下没有,则会到WEB-INF/lib目录下的jar文件中搜索: 3)如果还没 ...
- 从0开始学Java——JSP&Servlet——如何部署web应用程序
web容器要求应用程序部署时,需要像下面这样组织其目录结构: 手动去创建这样的目录结构还是挺麻烦的,所幸我们有开发工具,所以可以像下面这样来部署一个web项目. 1)确认程序代码已经完成: 2)在ec ...
- 从0开始学Java——JSP&Servlet——如何在Eclipse中配置Web容器为tomcat
windows- >Preferences -> Server->runtime Envirement ->Add 点击下一步,然后按照如下设置:
- 招新系统(jsp+servlet,实现简略前端网页注册登录+后台增删改查,分学生和管理员,Java语言,mysql数据库连接,tomcat服务器)
生活不只是眼前的苟且,还有诗和远方. 架构说明: 要求是采用MVC模式,所以分了下面的几个包,但是由于是第一次写,可能分的也不是很清楚: 这个是后台部分的架构: 这个是前端的的展示: (那个StuLo ...
- jsp+servlet分页查询
分页查询 减少服务器内存开销 提高用户体验 效果图 思绪图 分页显示Bean文件代码 package cn.ytmj.findlist.domain; import java.util.List; / ...
- Java面试题精选(三) JSP/Servlet Java面试逻辑题
-- JSP/Servlet Java面试逻辑题 -- 很显然,Servlet/JSP的WEB前端动态制作的重要性比HTML/CSS/JS的价值高很多,但我们都知道他们都是建立在HT ...
随机推荐
- 数据仓库开发——Kettle使用示例
Kettle是一个开园ETL工具,做数据仓库用Spoon. 工具:下载Spoon,解压即可用 1.认识常用组件: 表输入 插入\更新 数据同步 文本文件输出 ...
- spring源码:学习线索(li)
一.spring xml配置(不包括AOP,主要了解在初始化及实例化过程中spring配置文件中每项内容的具体实现过程,从根本上掌握spring) <bean>的名字 &,alia ...
- 如何:加载分页结果(WCF 数据服务)
WCF 数据服务 允许数据服务限制单个响应源中返回的实体数.在此情况下,源中的最后一项包含指向下一页数据的链接.通过调用执行 DataServiceQuery 时返回的 QueryOperationR ...
- 苹果的MDM简介
MDM(Mobile Device Management)移动设备管理,一般会用于企业管理其移动设备,鉴于iOS是比较封闭的系统很多的功能都难以实现,所以利用苹果的MDM可以达到远程控制设备,像远程定 ...
- 在VMware上安装VMTools
1. 什么是VMtools VM tools顾名思义就是Vmware的一组工具(关于如何在虚拟机上安装Linux,可以参考我之前的博文:http://www.cnblogs.com/libingbin ...
- 一个URL的物理文件的体现
场景 许多同学在开发过程中经常会遇到一个问题,怎么去定义一个url?以及定义一个url之后怎么根据一个url定义文件. 公司组织一次内部培训,为了把这次培训的内容以博客的形式共享出来. URL与文件的 ...
- Linix登录报"/etc/profile: line 11: syntax error near unexpected token `$'{\r''"
同事反馈他在一测试服务器(CentOS Linux release 7.2.1511)上修改了/etc/profile文件后,使用source命令不能生效,让我帮忙看看,结果使用SecureCRT一登 ...
- (八)map,filter,flatMap算子-Java&Python版Spark
map,filter,flatMap算子 视频教程: 1.优酷 2.YouTube 1.map map是将源JavaRDD的一个一个元素的传入call方法,并经过算法后一个一个的返回从而生成一个新的J ...
- 将现有MySQL数据库改为大小写不敏感
用过MySQL的应该都会注意到,默认情况下,Linux下安装的MySQL是大小写敏感的,也就是说Table1和table1可以同时存在.而Windows下的MySQL却是大小写不敏感的,所有表名和数据 ...
- 无法安装Windows Live“OnCatalogResult:0x80190194”错误的解决方法
今天想安装一个博客客户端,结果安装一直报错"OnCatalogResult:0x80190194",百度查到了解决发放再此记录下来,以备后用. 到官网下载了一个在线安装程序,可是一 ...