亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JSP > 正文

jsp+servlet+javabean實現數據分頁方法完整實例

2020-07-27 21:28:51
字體:
來源:轉載
供稿:網友

本文實例講述了jsp+servlet+javabean實現數據分頁方法。分享給大家供大家參考,具體如下:

這里秉著且行且記的心態,記錄下學習過程,學得快忘得快,生怕遺忘,以備日后使用。
用到的部分代碼是自己在網上查找,并自己修改,加上自己的理解。也不知道算不算原創,只做自己學習記錄。

使用相關:PostgreSQL數據庫、dom4j、JSP、Servlet

一、首先是工程格局,來個全局視圖方便讀者與自己查看與使用

思路為:

以config.xml文件記錄配置信息,以方便數據庫更改,方便移植與重用。
DOM4JUtil.java用于解析xml屬性文件以獲得需要數據
PostgreSQL_Util.java分裝數據連接與數據庫操作
PageProperties.java為表格分頁屬性javaBean
PageProperties.java封裝分頁操作
Page.java為分頁主要操作
tablePage.jsp為效果顯示界面

用到的第三方jar包:

dom4j-1.6.1.jar用于xml文件解析
postgresql-9.3-1101.jdbc4.jar用于JDBC連接postgreSQL數據庫

分頁效果如下:能通過點擊上頁下頁實現翻頁,輸入指定頁面跳轉(超出范圍跳轉到第1或最后頁)。具體實現請參見詳細代碼,我都貼上來了。小菜鳥一名,處于正在學習階段,有大神能指點下當然更好,希望不吝賜教!

二、具體代碼實現

1、config.xml數據庫連接信息屬性文件

<?xml version="1.0" encoding="utf-8"?><!DOCTYPE postgres[ <!ELEMENT postgres (driver,url,username,pwd)> <!ELEMENT driver (#PCDATA)> <!ELEMENT url (#PCDATA)> <!ELEMENT username (#PCDATA)> <!ELEMENT pwd (#PCDATA)>]><postgres> <driver>org.postgresql.Driver</driver> <url>jdbc:postgresql://localhost:5432/java</url> <username>admin</username> <pwd>k42jc</pwd></postgres>

2、DOM4JUtil.java

package util;import org.dom4j.Document;import org.dom4j.DocumentException;import org.dom4j.Element;import org.dom4j.io.SAXReader;/**  * 用于解析xml屬性文件  * @author JohsonMuler  *  */public class DOM4JUtil { private static Element root=null; static{//靜態代碼塊  //創建解析對象  SAXReader sr=new SAXReader();  //獲取當前工程路徑//  String url=System.getProperty("user.dir");  String url=DOM4JUtil.class.getResource("").getPath();//  System.out.println(url);  try {   //通過文件路徑獲取配置文件信息   Document doc=sr.read(url+"config.xml");   //獲取根節點   root=doc.getRootElement();  } catch (DocumentException e) {   e.printStackTrace();  } } public static String getPostgresData(String str){  //以根節點為基礎,獲取配置文件數據  Element e=root.element(str);  String data=e.getText();  return data; } public static void main(String[] args) {//  String url=DOM4JUtil.class.getResource("..").getPath();//  System.out.println(System.getProperty("user.dir"));//  System.out.println(url);  String driver=getPostgresData("driver");  String url=getPostgresData("url");  System.out.println(driver);  System.out.println(url); }}

3、PostgreSQL_Util.java

package util;import java.sql.PreparedStatement;import java.sql.Statement;import java.sql.Connection;import java.sql.DriverManager;import java.sql.ResultSet;import java.sql.SQLException;import java.util.List;public class PostgreSQL_Util { private static DOM4JUtil dom=new DOM4JUtil(); private static Connection c=null; private static ResultSet rs=null; private static String driver=dom.getPostgresData("driver"); private static String url=dom.getPostgresData("url"); private static String username=dom.getPostgresData("username"); private static String pwd=dom.getPostgresData("pwd"); public PostgreSQL_Util(){  try {   Class.forName(driver);   c=DriverManager.getConnection(url);  } catch (ClassNotFoundException e) {   System.out.println("未找到指定類:"+e.getMessage());  } catch (SQLException e) {   System.out.println("獲取連接異常:"+e.getMessage());  } } /**  * 數據查詢方法(Statement)  * @param sql  * @return  * @throws SQLException  */ public ResultSet executeQuery(String sql) throws SQLException{  Statement s=c.createStatement();  rs=s.executeQuery(sql);  return rs; } /**  * 重載方法(PreparedStatement)  * @param sql  * @param list  * @return  * @throws SQLException  */ public ResultSet executeQuery(String sql,List<Object> list) throws SQLException{  PreparedStatement ps=c.prepareStatement(sql);  for(int i=0;i<list.size();i++){   System.out.println(list.get(i));   System.out.println(i+1);   ps.setObject(i+1, list.get(i));  }  rs=ps.executeQuery();  c.close();  return rs; } /**  * 數據更新方法(添加,刪除,更改)(Statement)  * @param sql  * @throws SQLException  */ public int executeUpdate(String sql) throws SQLException{  Statement s=c.createStatement();  int i=s.executeUpdate(sql);  c.close();  return i; } /**  * 重載方法(PreparedStatement)  * @param sql  * @param list  * @throws SQLException  */ public int executeUpdate(String sql,List<Object> list) throws SQLException{  PreparedStatement ps=c.prepareStatement(sql);  for(int i=0;i<list.size();i++){   ps.setObject(i+1, list.get(i));  }  int i=ps.executeUpdate();  c.close();  return i; } /**  * 單獨的獲取連接  * @return  * @throws ClassNotFoundException  * @throws SQLException  */ public static Connection getConnection() throws ClassNotFoundException, SQLException{  Class.forName(driver);  c=DriverManager.getConnection(url);  return c; }}

4、PageProperties.java

package bean;import java.sql.ResultSet;public class PageProperties { private int currentPage;//當前頁號 private int totalPages;//總頁數 private int totalRecords;//總數據條數 private ResultSet rs;//動態結果集 public PageProperties() {  super(); } public PageProperties(int currentPage, int totalPages, int totalRecords,    ResultSet rs) {  super();  this.currentPage = currentPage;  this.totalPages = totalPages;  this.totalRecords = totalRecords;  this.rs = rs; } public int getCurrentPage() {  return currentPage; } public void setCurrentPage(int currentPage) {  this.currentPage = currentPage; } public int getTotalPages() {  return totalPages; } public void setTotalPages(int totalPages) {  this.totalPages = totalPages; } public int getTotalRecords() {  return totalRecords; } public void setTotalRecords(int totalRecords) {  this.totalRecords = totalRecords; } public ResultSet getRs() {  return rs; } public void setRs(ResultSet rs) {  this.rs = rs; }}

5、TablePage.java

package bean;import java.sql.ResultSet;public class PageProperties { private int currentPage;//當前頁號 private int totalPages;//總頁數 private int totalRecords;//總數據條數 private ResultSet rs;//動態結果集 public PageProperties() {  super(); } public PageProperties(int currentPage, int totalPages, int totalRecords,    ResultSet rs) {  super();  this.currentPage = currentPage;  this.totalPages = totalPages;  this.totalRecords = totalRecords;  this.rs = rs; }  public int getCurrentPage() {  return currentPage; } public void setCurrentPage(int currentPage) {  this.currentPage = currentPage; } public int getTotalPages() {  return totalPages; } public void setTotalPages(int totalPages) {  this.totalPages = totalPages; } public int getTotalRecords() {  return totalRecords; } public void setTotalRecords(int totalRecords) {  this.totalRecords = totalRecords; } public ResultSet getRs() {  return rs; } public void setRs(ResultSet rs) {  this.rs = rs; }}

6、Page.java這是主要處理類,Servlet

package servlet;import java.io.IOException;import java.io.PrintWriter;import java.sql.ResultSet;import java.sql.SQLException;import javax.servlet.ServletException;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import util.PostgreSQL_Util;import bean.PageProperties;import bean.TablePage;public class Page extends HttpServlet { public void service(HttpServletRequest request, HttpServletResponse response)   throws ServletException, IOException {  request.setCharacterEncoding("utf-8");  response.setContentType("text/html;charset=utf-8");  PrintWriter out = response.getWriter();  /**   * 通過TablePage設置分頁屬性   *   */  TablePage tb=new TablePage();  //獲取當前表格顯示的頁碼  int currentPage=tb.currentPage(tb.getStrPage(request, "page"));  System.out.println(currentPage);  //設置每頁顯示數據條數  tb.setPageRecord(10);//設置每頁顯示10條數據  /**   * 通過xxSQL_Util設置JDBC連接及數據處理   */  PostgreSQL_Util postgres=new PostgreSQL_Util();  try {   ResultSet rs_count=postgres.executeQuery("select count(*) as c from student");   rs_count.next();   //獲得總的數據條數   int totalRecords=rs_count.getInt("c");   //根據數據表的總數據條數獲取頁面顯示表格的總頁數   int totalPages=tb.getTotalPages(totalRecords);   if(currentPage>totalPages){    currentPage=totalPages;//保證最后一頁不超出范圍   }   //根據數據庫表信息和當前頁面信息獲得動態結果集   ResultSet rs=tb.getPageResultSet(postgres.executeQuery("select * from student"), currentPage);   /**     * 將數據加入javaBean    */   PageProperties pp=new PageProperties(currentPage, totalPages, totalRecords, rs);   /**     * 將javaBean轉發至前端     */    request.setAttribute("result", pp);   request.getRequestDispatcher("tablePage.jsp").forward(request, response);  } catch (SQLException e) {   System.out.println("Class Page:"+e.getMessage());//   e.printStackTrace();  } }}

7、tablePage.jsp前臺顯示效果

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%><%@page import="java.sql.ResultSet"%><%@page import="bean.PageProperties"%><%@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> <title>簡單數據分頁</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css"> --> </head> <body> <table>  <tr>   <td>姓名</td>   <td>性別</td>   <td>年齡</td>   <td>分數</td>  </tr>  <%   PageProperties pp=(PageProperties)request.getAttribute("result");    ResultSet rs=pp.getRs();  %>  <%   int i=1;   while(rs.next()){   %>  <tr>   <td><%=rs.getObject(1) %></td>   <td><%=rs.getObject(2) %></td>   <td><%=rs.getObject(3) %></td>   <td><%=rs.getObject(4) %></td>  </tr>  <%   i++;   if(i>10)    break;  }   %>   <br/>   <span><%=pp.getTotalPages() %>頁</span>  <span>共<%=pp.getTotalRecords() %>條數據</span>  <span>本頁<%=i-1 %>條</span>  <span>第<%=pp.getCurrentPage() %>頁</span>  <p align="center">   <%    if ( pp.getCurrentPage() > 1 )    {   %><a href="<%=path %>/page?page=<%=pp.getCurrentPage() - 1%>"><<上一頁</a>   <%    }   %>   <%    if ( pp.getCurrentPage() < pp.getTotalPages() )    {   %><a href="<%=path %>/page?page=<%=pp.getCurrentPage() + 1%>">下一頁>></a>   <%    }   %>   <input type="text" name="input_text" id="input_text" size="1" />    <input type="button" name="skip" id="skip" value="跳轉" onclick="skip();"/>   <script>    function skip(){     var v=document.getElementById("input_text").value;     location.href="page?page="+v;    }   </script>  </p> </table> </body></html>

初步看,感覺后臺代碼實在是繁瑣,但這是考慮到程序健壯性與可移植性,方便代碼重用。以后要用,根據自己的需要在屬性文件(config.xml)中配置相關JDBC驅動,在jsp頁面通過request獲得后臺Servlet(Page.jsp)的轉發結果("result"),結合頁面屬性(PageProperties.java類)即可實現效果。

當然,這也是因為個人學習,傾向于多用點東西。

希望本文所述對大家jsp程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩hd视频在线观看| 热99精品里视频精品| 91精品免费视频| 欧美在线一级va免费观看| 蜜臀久久99精品久久久无需会员| 亚洲天堂网在线观看| 欧美激情免费在线| 久久精品国产欧美亚洲人人爽| 亚洲最大成人在线| 久久99国产精品自在自在app| 97碰在线观看| 最新日韩中文字幕| 欧美在线视频导航| 奇米成人av国产一区二区三区| 精品国产精品自拍| 中文字幕在线国产精品| 亚洲男人av电影| 欧美国产日本在线| 97在线精品国自产拍中文| 欧美激情精品久久久久久变态| 欧美日本国产在线| 亚洲在线观看视频网站| 日韩中文字幕在线视频| 欧美日韩999| 亚洲精品国产电影| www.美女亚洲精品| 国产成人精品一区二区| 精品美女久久久久久免费| 91久久久久久久一区二区| 国产一级揄自揄精品视频| 91中文精品字幕在线视频| 日本最新高清不卡中文字幕| 欧美日韩久久久久| 国产小视频91| 91亚洲精品久久久久久久久久久久| 精品激情国产视频| 国语自产精品视频在线看一大j8| 国产精品亚洲一区二区三区| 久久久久久久久久久网站| 成人国产精品久久久| 92福利视频午夜1000合集在线观看| 成人黄色免费片| 一区二区三区黄色| 亚洲va国产va天堂va久久| 最近2019年手机中文字幕| 国产成人一区三区| 欧美大片网站在线观看| 国产91精品青草社区| 午夜精品理论片| 久久久噜噜噜久噜久久| 日韩激情视频在线播放| 欧洲成人免费aa| 91在线观看免费网站| 国产噜噜噜噜久久久久久久久| 亚洲国模精品私拍| 日韩的一区二区| 久久99精品久久久久久噜噜| 国产精品va在线播放我和闺蜜| 日韩高清免费在线| 国产日韩欧美视频| 69**夜色精品国产69乱| 日韩国产高清污视频在线观看| 97欧美精品一区二区三区| 中文字幕国产日韩| 国产精品视频午夜| 中文字幕亚洲综合久久筱田步美| 欧美精品在线观看91| 欧美日韩黄色大片| 国产精品a久久久久久| 66m—66摸成人免费视频| 久久久国产视频| 欧美成人剧情片在线观看| 欧美疯狂性受xxxxx另类| 在线观看欧美成人| 欧美怡红院视频一区二区三区| 亚洲美女免费精品视频在线观看| 精品日本美女福利在线观看| 国产成人91久久精品| 国产日本欧美视频| 一区二区三区 在线观看视| 国内精品久久久久久久| 国产一区二区激情| 欧美黑人又粗大| 米奇精品一区二区三区在线观看| 精品久久久中文| 欧美午夜精品久久久久久久| 国产色视频一区| 狠狠操狠狠色综合网| 日韩欧美中文第一页| 欧美中文字幕精品| 欧美日韩视频免费播放| 国产精品美女午夜av| 国产日韩欧美在线播放| 成人做爰www免费看视频网站| 国内精品久久久久久中文字幕| 久久五月天色综合| 亚洲人成亚洲人成在线观看| 一本一本久久a久久精品牛牛影视| 成人免费在线视频网址| 国产精品久久久久久一区二区| 国产精品免费看久久久香蕉| 午夜精品三级视频福利| 久久久久国色av免费观看性色| 国产精品视频久久久| 性欧美xxxx视频在线观看| 成人在线视频福利| 久久99精品久久久久久噜噜| 欧美性猛交xxxx| 欧美日韩在线视频一区| 久久99国产综合精品女同| 日韩三级影视基地| 国产成人精品视频在线观看| 欧美在线观看日本一区| 欧美黑人性猛交| 在线观看精品自拍私拍| 日本不卡视频在线播放| 精品人伦一区二区三区蜜桃免费| 成人观看高清在线观看免费| 国产精品专区h在线观看| 国产亚洲精品高潮| 亚洲大尺度美女在线| 久久久久五月天| 中文字幕亚洲综合久久筱田步美| 久久亚洲精品一区| 久久久女人电视剧免费播放下载| 成人免费福利在线| 亚洲日韩中文字幕在线播放| 亚洲高清免费观看高清完整版| 中文字幕在线看视频国产欧美在线看完整| 久久6精品影院| 国产成人小视频在线观看| 91精品国产精品| 日韩欧美第一页| 精品久久久91| 欧美在线视频播放| 韩国视频理论视频久久| xxxxxxxxx欧美| 欧美黑人又粗大| 琪琪亚洲精品午夜在线| 日韩av在线免费观看一区| 欧美极品欧美精品欧美视频| 国产精品成熟老女人| 成人写真福利网| 91在线直播亚洲| 国内精品免费午夜毛片| 中文字幕av一区中文字幕天堂| 波霸ol色综合久久| 日韩中文字幕精品| 国产精品久久久久久久久久久久| 精品成人在线视频| 久久在线精品视频| 欧美一级高清免费播放| 久久男人的天堂| 欧美中文字幕在线观看| 欧美理论电影在线播放| 91欧美视频网站| 色www亚洲国产张柏芝| 国产精品久久久久久久一区探花| 成人久久精品视频| 91av网站在线播放| 欧美性做爰毛片| 国产一区玩具在线观看| 久热精品视频在线观看| 国产精品久久久久久久一区探花|