婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > jsp+servlet+javabean實現數據分頁方法完整實例

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

熱門標簽:電銷機器人是有一些什么技術 杭州ai語音電銷機器人功能 北票市地圖標注 杭州語音電銷機器人軟件 商洛電銷 地圖標注線上教程 高德地圖標注樣式 四川保險智能外呼系統商家 電銷機器人好賣么

本文實例講述了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,ListObject> list) throws SQLException{
  PreparedStatement ps=c.prepareStatement(sql);
  for(int i=0;ilist.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,ListObject> list) throws SQLException{
  PreparedStatement ps=c.prepareStatement(sql);
  for(int i=0;ilist.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程序設計有所幫助。

您可能感興趣的文章:
  • jsp頁面數據分頁模仿百度分頁效果(實例講解)
  • nodejs個人博客開發第六步 數據分頁
  • JSP數據分頁導出下載顯示進度條樣式
  • JS代碼實現table數據分頁效果
  • 無JS,完全php面向過程數據分頁實現代碼
  • JSP數據庫操數據分頁顯示
  • jquery+json實現數據列表分頁示例代碼
  • js前臺分頁顯示后端JAVA數據響應
  • JS實現table表格數據排序功能(可支持動態數據+分頁效果)
  • js對象實現數據分頁效果

標簽:西藏 紅河 青島 云浮 貴州 丹東 宿州 江西

巨人網絡通訊聲明:本文標題《jsp+servlet+javabean實現數據分頁方法完整實例》,本文關鍵詞  jsp+servlet+javabean,實現,數據,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《jsp+servlet+javabean實現數據分頁方法完整實例》相關的同類信息!
  • 本頁收集關于jsp+servlet+javabean實現數據分頁方法完整實例的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    91丝袜国产在线播放| 亚洲sss视频在线视频| 日韩精品一区二| 国产精品久久久久久久久免费丝袜 | 精品久久久久香蕉网| 国产精品国产三级国产| 日韩不卡一区二区三区| 在线一区二区三区四区五区 | 欧美午夜精品久久久| 国产精品情趣视频| 伊人夜夜躁av伊人久久| 国产高清不卡二三区| 欧美日韩mp4| 一区二区三区四区高清精品免费观看| 蜜臀精品一区二区三区在线观看| 欧美日韩美少妇| 日韩av一区二区三区| 欧美人妖巨大在线| 麻豆精品在线看| 久久久精品黄色| 国产老肥熟一区二区三区| 日韩精品一区二区三区三区免费| 久久精品国产77777蜜臀| 911精品国产一区二区在线| 国产三级欧美三级| 91欧美一区二区| 强制捆绑调教一区二区| 日韩美女主播在线视频一区二区三区 | 粉嫩av亚洲一区二区图片| 国产精品久久福利| 91免费观看国产| 日日骚欧美日韩| 国产精品毛片久久久久久| 欧美日韩和欧美的一区二区| 国产成人自拍在线| 日韩精品一二区| 亚洲精品免费一二三区| 精品成人在线观看| 日韩午夜在线观看| 欧美丝袜自拍制服另类| 99在线视频精品| 国产69精品久久777的优势| 香蕉成人伊视频在线观看| 亚洲婷婷综合色高清在线| 欧美成人国产一区二区| 欧美午夜精品久久久| 色婷婷一区二区| 欧美日韩精品二区第二页| 777亚洲妇女| 欧美精品一区二区不卡| 日韩欧美国产wwwww| 欧美一区二区三区喷汁尤物| 日韩欧美国产综合| 国产精品视频看| 亚洲免费三区一区二区| 亚洲一区二区三区小说| 五月婷婷久久丁香| 精品在线一区二区| 成人av在线看| 91精品国产aⅴ一区二区| 久久亚洲欧美国产精品乐播| 久久婷婷国产综合精品青草| 久久九九久久九九| 亚洲伦理在线免费看| 美女一区二区三区| 91国偷自产一区二区开放时间 | 在线亚洲+欧美+日本专区| 欧洲视频一区二区| 2欧美一区二区三区在线观看视频| 国产精品久久久久久亚洲伦| 亚洲自拍都市欧美小说| 国产高清在线观看免费不卡| 日本韩国一区二区三区| 欧美一区二区三区喷汁尤物| 亚洲欧美日韩中文字幕一区二区三区| 无码av免费一区二区三区试看 | 国产福利电影一区二区三区| 欧美日韩电影一区| 亚洲日本va午夜在线电影| 国产精品88888| 精品免费一区二区三区| 日本欧美大码aⅴ在线播放| 在线免费观看日本欧美| 中文字幕日本不卡| 成人理论电影网| 国产精品女主播在线观看| 国产成人午夜精品影院观看视频| 日韩你懂的电影在线观看| 久久精品国产免费| 日韩天堂在线观看| 国产一区二区精品久久| 日韩精品一区二区三区在线观看 | 国产精品99久久久久久似苏梦涵| 欧美日韩成人在线| 韩国欧美一区二区| 国产人成一区二区三区影院| 国产精品一区二区黑丝| 国产精品欧美久久久久无广告| 国产一区 二区| 亚洲综合精品自拍| 精品国产髙清在线看国产毛片| 视频一区中文字幕国产| 日韩视频免费观看高清完整版 | 在线视频国产一区| 日本aⅴ精品一区二区三区 | 高清在线观看日韩| 午夜一区二区三区在线观看| 91精品国产综合久久香蕉麻豆| 国产精品一级在线| 亚洲一区二三区| 精品91自产拍在线观看一区| 91电影在线观看| 99在线精品一区二区三区| 奇米精品一区二区三区四区 | 亚洲午夜免费视频| 久久久久久久精| 在线不卡a资源高清| 欧美aaaaaa午夜精品| 成人福利视频在线看| 91毛片在线观看| 国产精品一区二区你懂的| 性欧美大战久久久久久久久| 在线亚洲高清视频| a在线播放不卡| 国产成人精品aa毛片| 精品一区二区三区香蕉蜜桃| 国产精品免费av| 国产女人18毛片水真多成人如厕 | 免费高清在线一区| 亚洲午夜一二三区视频| 欧美激情一区二区三区| wwwwww.欧美系列| 国产日本欧洲亚洲| 国产亚洲精品中文字幕| 久久亚洲精精品中文字幕早川悠里 | 国产成人在线电影| 国产成人鲁色资源国产91色综| 日韩中文字幕不卡| 丝袜诱惑亚洲看片| 久久97超碰色| 在线精品观看国产| 91精品婷婷国产综合久久性色 | 91精品国产免费| 精品国产污污免费网站入口| 国产欧美日韩精品在线| 亚洲成人精品一区二区| 国产高清不卡二三区| 91免费国产在线观看| 欧美成人一级视频| 亚洲综合色婷婷| 国产成人aaa| 日韩一级黄色大片| 亚洲国产日韩在线一区模特| 国产福利视频一区二区三区| 91麻豆精品国产综合久久久久久 | 亚洲精品国产精华液| 国产精品99久久久| 久久久久久久久久久久久女国产乱 | 亚洲自拍都市欧美小说| 麻豆免费看一区二区三区| 欧美亚洲免费在线一区| 一区在线播放视频| 成人av在线资源| 中文字幕一区二区三中文字幕| 久久99久国产精品黄毛片色诱| 欧美一区二区三区日韩视频| 日韩精品高清不卡| 欧美一区二区三区喷汁尤物| 免费一级片91| 久久久99精品免费观看不卡| 国产91在线观看| 成人欧美一区二区三区小说| 色老头久久综合| 日韩精品三区四区| 精品国产亚洲一区二区三区在线观看| 蜜臀久久99精品久久久久宅男| 亚洲精品在线网站| 在线精品观看国产| 国产福利精品导航| 亚洲国产精品久久久男人的天堂| 欧美午夜精品久久久| 亚洲v日本v欧美v久久精品| 欧美日韩精品三区| 免费在线观看一区二区三区| 激情欧美一区二区| 亚洲国产高清在线观看视频| 欧美性xxxxxxxx| 成人网在线播放| 日本麻豆一区二区三区视频| 国产精品美女视频| wwwwxxxxx欧美| 日韩欧美一级精品久久| aaa亚洲精品一二三区| 国产精品亚洲午夜一区二区三区| 亚洲一区二区欧美激情| 亚洲丝袜美腿综合| 亚洲国产成人一区二区三区| 欧美日韩亚洲高清一区二区| 91色九色蝌蚪| 国产精品一二三在|