jsp实现分页显示信息(数据库、EL表达式、连接池)
来源:互联网 发布:火狐debug调试js脚本 编辑:程序博客网 时间:2024/04/29 08:05
一、准备工作
1.1在mysql数据库中你建立学生的表
1.2细节:
1.2.0. 先导入musql的jar包 1.2.1. 性别一般用枚举型 1.2.2. 要将表转储sql文件,放在web项目额web-info下面 1.2.3. 在删除sql文件中的一些信息时,会出现中文乱码问题,这时候一定不要保存,先“右键”sql文件,把字符集修改为 1.2.4. 因为要用到连接池,先把context.xml放到meta-info下面
二、javabean(属性私有化、do/get方法、空参构造函数、带参构造函数):
package com.bright.bean;public class Student { private int id; private String name; private String sex; private String clazz; 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 String getSex() { return sex; } public void setSex(String sex) { this.sex = sex; } public String getClazz() { return clazz; } public void setClazz(String clazz) { this.clazz = clazz; } public Student() { super(); } public Student(int id, String name, String sex, String clazz) { super(); this.id = id; this.name = name; this.sex = sex; this.clazz = clazz; }}
三、学生信息初始化(将信息存入到数据库中,有了这个就不需要sql文件了)
package init;import java.sql.*;import java.util.Random;import com.bright.bean.*;public class StudentInit { public static void main(String[] args) { //连接数据库(用JDBC连接) try { Class.forName("com.mysql.jdbc.Driver"); Connection conn=DriverManager.getConnection("jdbc:mysql:///student", "root", "123"); PreparedStatement stat=conn.prepareStatement("insert into student values (null,?,?,?)");//因为id是自增长的 //假设有88个学生,每个班20人,分成了5个班(外循环控制班级,内循环控制每个班的学生人数20人) for (int i = 1; i < 6; i++) { for(int j=1;j<21;j++) { String sex="男"; //生成一个随机整数 if(new Random().nextInt()%2==0) { sex="女"; } Student stu=new Student(0, i+"班的"+j+"号学生", sex, i+"班"); //存储 stat.setString(1, stu.getName()); stat.setString(2, stu.getSex()); stat.setString(3, stu.getClazz()); stat.executeUpdate(); //循环到最后一个人了就退出循环 if(i==5&&j==8) { break; } } } conn.close(); } catch (Exception e) { e.printStackTrace(); } }}
四、servlet处理数据(分页一般用get处理):
package com.bright.servlet;import java.io.IOException;import java.io.PrintWriter;import java.sql.Connection;import java.sql.PreparedStatement;import java.sql.ResultSet;import java.util.ArrayList;import java.util.List;import javax.naming.Context;import javax.naming.InitialContext;import javax.naming.NamingException;import javax.servlet.ServletException;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import javax.sql.DataSource;import com.bright.bean.Student;public class PageServlet extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //声明四个参数 long rows=0; //数据总数(可能比较长,就定义为了long) int size=10; //每一页显示的记录条数 int page=1; //当前第几页 int pageCount=0;//一共有多少页 String pn=request.getParameter("page");//通过参数获取page(当前是第几页) //得到当前是第几页 if(pn!=null && pn.length()>0) { try { page=Integer.parseInt(pn); //进行类型转换(得到的是一个字符串) } catch (NumberFormatException e) { e.printStackTrace(); page=1; //如过又错,就返回第一页得到信息 } } //使用连接池 try { InitialContext initCtx = new InitialContext(); Context ctx=(Context) initCtx.lookup("java:comp/env"); DataSource ds=(DataSource) ctx.lookup("jdbcmysql"); Connection conn=ds.getConnection(); PreparedStatement stat=conn.prepareStatement("select count(*) as rows from student");//先从数据库中取到所有的数据 ResultSet rs=stat.executeQuery();//将查询到的结果放到结果集中 //有下一条 if(rs.next()) { rows=rs.getLong("rows");//得到数据总数 } //计算pageCount(总页数) if(rows%size==0) { pageCount=(int)(rows/size); }else{ pageCount=(int)(rows/size)+1; } //将查询到的数据放到List集合中 List<Student> list=new ArrayList<Student>(); //使用SQL进行分页(两个问号分别代表每一页的开头和结尾) stat=conn.prepareStatement("select * from student limit ?,?"); stat.setInt(1,(page-1)*size);//每一页的开头 stat.setInt(2, size);//每一页的结尾 rs=stat.executeQuery(); while(rs.next()) { Student s=new Student(); s.setId(rs.getInt(1)); s.setName(rs.getString(2)); s.setSex(rs.getString(3)); s.setClazz(rs.getString(4)); list.add(s); } conn.close(); //将数据发送给JSP页面,并实现转发 request.setAttribute("list", list); request.setAttribute("pageCount", pageCount);//总页数 request.setAttribute("page", page);//当前显示页 request.getRequestDispatcher("/page.jsp").forward(request, response); } catch (Exception e) { e.printStackTrace(); } } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doGet(request,response); }}
五(1)、配置文件XML:
<?xml version="1.0" encoding="UTF-8"?><web-app version="3.0" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"> <display-name></display-name> <servlet> <servlet-name>PageServlet</servlet-name> <servlet-class>com.bright.servlet.PageServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>PageServlet</servlet-name> <url-pattern>/ps</url-pattern> </servlet-mapping> <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list></web-app>
五(2)、连接池连接的文件:
<?xml version="1.0" encoding="UTF-8"?><Context><!-- name: jndi中的名字,servlet中,就通过该名字获取数据源 type: 对象的类型 maxActive: 最大活动连接数(没有被使用的连接数) maxIdle: 最大连接数 maxWait: 如果没有连接,等待连接的时间,-1表示无限等待 .... --> <Resource name="jdbcmysql" auth="Container" type="javax.sql.DataSource" maxActive="5" maxIdle="5" maxWait="-1" driverClassName="com.mysql.jdbc.Driver" username="root" password="123" url="jdbc:mysql:///student"/>//student是数据库的名称</Context>
六、静态页面(用jsp显示)
6.1.
<%@ page language="java" import="java.util.*" contentType="text/html; charset=utf-8"%><%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %><%String path = request.getContextPath();String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";%><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"><html> <head> <base href="<%=basePath%>"> </head> <body> <center> <table border="1" cellpadding="0" cellspacing="0" width="50%"> <caption>学生信息显示</caption> <tr> <th>序号</th> <th>ID</th> <th>姓名</th> <th>性别</th> <th>班级</th> </tr> <c:choose> <c:when test="${empty list}"> <tr> <td colspan="5">没有学生信息</td> </tr> </c:when> <c:otherwise> <c:forEach items="${list}" var="st" varStatus="index"> <tr> <td>${index.count}</td> <td>${st.id}</td> <td>${st.name}</td> <td>${st.sex}</td> <td>${st.clazz}</td> </tr> </c:forEach> <tr> <td colspan="5"> <c:if test="${!(page==1)}"> <a href="ps?page=${page-1 }">上一页</a> </c:if> <c:forEach var="p" begin="1" end="${pageCount }"> <a href="ps?page=${p}">第${p}页</a> </c:forEach> <c:if test="${!(page==pageCount)}"> <a href="ps?page=${page+1 }">下一页</a> </c:if> </td> </tr> </c:otherwise> </c:choose> </table> </center> </body></html>
6.2. 细节:①使用了EL表达式,在page中要有
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
②表格的第一列要有编号③<c:choose>中有<c:when>可有多个和<c:otherwise>,<c:otherwise>中有<forEach>
七 、运行结果(部分):
八、小结
1、通过http:localhost:8080/pagination/ps(这时候访问的是servlet)
2、servlet中的思路:
(1)连接数据库,从数据库中查询到所有数据,进行预处理,将查询到的所有数据方法哦结果集中–>知道数据总数rows
(2)根据数据总数,通过公式就可以得到总页数pageCount
(3)通过sql语句进行分页(这时候有两个未知量,一个是每一页的起始位置,另一个是每一页的结尾)
①通过sql语句查询数据库--->进行预处理(有几个问好就存储几个数据) ②将查询到的结果放到结果集中 ③如果有下一条,就取出查询到的所有数据,给stu赋值 ④将stu添加到集合中(4)将集合,总页数,当前页数放到request中(5)进行重定向(就跳转到jsp页面显示数据了)
0 0
- jsp实现分页显示信息(数据库、EL表达式、连接池)
- jsp实现分页显示信息(数据库、EL表达式、连接池)
- jsp连接数据库实现信息分页
- JSP连接数据库实现分页显示
- jsp连接数据库分页显示
- JSP连接SQL数据库实现数据分页显示
- 实现JSP分页显示数据库
- jsp EL表达式结合JSTL标准标签实现分页
- jsp实现分页显示图书信息
- 实验二:分页显示数据库信息(jsp页面直接分页)
- JSP实现数据库分页显示源代码
- jsp实现读取数据库数据分页显示
- JSP实现分页显示
- EL 表达式:jsp中显示实例属性
- EL表达式 用于JSP中显示数据
- (转载)JSP EL表达式
- 表达式语言(EL)---JSP
- 《实现JSP分页显示数据库》的阅读笔记
- web开发使用Javabean
- 图片圆角处理方法
- EJB 设计模式概述
- LeetCode -- 292. Nim Game
- JDK配置环境变量详解
- jsp实现分页显示信息(数据库、EL表达式、连接池)
- RxJava基础与创建操作符
- 如何阅读一本书(9)
- 归并排序两种实现
- 欢迎使用CSDN-markdown编辑器
- 2016年4月9日港澳之旅
- AngularJS使用心得(持续更新中)
- (Java实现) HDOJ 1051 Wooden Sticks 贪心算法
- LeetCode -- 342. Power of Four