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 ...
随机推荐
- C标准头文件<math.h>
定义域错误可以理解为超出了函数的适用范围,如果发生了定义域错误,设errno为EDOM 如果结果不能表示为double值,则发生值域错误,如果结果上溢,则函数返回HUGE_VAL的值,设errno为E ...
- python爬虫成长之路(一):抓取证券之星的股票数据
获取数据是数据分析中必不可少的一部分,而网络爬虫是是获取数据的一个重要渠道之一.鉴于此,我拾起了Python这把利器,开启了网络爬虫之路. 本篇使用的版本为python3.5,意在抓取证券之星上当天所 ...
- Redis主从复制
大家可以先看这篇文章ASP.NET Redis 开发对Redis有个初步的了解 Redis的主从复制功能非常强大,一个master可以拥有多个slave,而一个slave又可以拥有多个slave,如此 ...
- js 隐式转换
1.数字number与字符串string相加的就,最后会得到一个字符串string:'1'+3='13' 2.数字number与字符串string相减,最后会得到一个数字number:'1'-0=1, ...
- HTML5学习总结——canvas绘制象棋(canvas绘图)
一.HTML5学习总结——canvas绘制象棋 1.第一次:canvas绘制象棋(笨方法)示例代码: <!DOCTYPE html> <html> <head> & ...
- 使用 Web API 模拟其他用户
模拟的要求 模拟可代表另一个 Microsoft Dynamics CRM 用户,用于执行业务逻辑(代码)以便提供所需功能或服务,它使用模拟用户的相应角色和基于对象的安全性.这项技术很有必要,因为 M ...
- 特大喜讯,View and Data API 现在支持中文界面了
大家经常会问到,使用View and Data API怎么做界面的本地化,来显示中文,现在好消息来了,从v1.2.19起,View and Data API开始支持多国语言界面了.你需要制定版本号为v ...
- Android游戏开发实践(1)之NDK与JNI开发02
Android游戏开发实践(1)之NDK与JNI开发02 承接上篇Android游戏开发实践(1)之NDK与JNI开发01分享完JNI的基础和简要开发流程之后,再来分享下在Android环境下的JNI ...
- RecyclerView 的介绍以及多布局的实例
RecyclerView 的使用以及多布局的实例 RecyclerView 是在Android5.0之后推出的,是一个比ListView更加灵活更加高效的适配器类型控件.但是RecyclerView不 ...
- 数据备份的OSS接口
最近在做一个新的项目,从RDS备份到OSS,进行数据备份以及后续的还原.这边对阿里云的OSS数据上传接口进行说明,先做下笔记先简单介绍下OSS: ①Object 在OSS中,用户操作的基本数据单元是O ...