本文實例講述了jsp+servlet+javabean實作資料分頁方法。分享給大家供大家參考,具體如下:
這裡秉著且行且記的心態,記錄下學習過程,學得快忘得快,生怕遺忘,以備日後使用。
用到的部分程式碼是自己在網路上找,並且自行修改,加上自己的理解。也不知道算不算原創,只做自己學習記錄。
使用相關:PostgreSQL資料庫、dom4j、JSP、Servlet
一、首先是工程格局,來個全域視圖方便讀者與自己查看與使用
思路為:
思路為:
。訊息,以方便資料庫更改,方便移植與重複使用。
DOM4JUtil.java用於解析xml屬性檔案以獲得需要資料
PostgreSQL_Util.java分裝資料連線與資料庫操作
PageProperties.java封裝分頁運算tablePage.jsp效果顯示介面
用到的第三方jar包:
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、Postgre 、TablePage.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; } }6、Page.java這是主要處理類,Servlet
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; } }7、tablePage.jsp前台顯示效果
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; } }初步看,感覺後台程式碼實在是繁健瑣程式性與可移植性,方便程式碼重複使用。以後要用,依照自己的需求在屬性檔(config.xml)中配置相關JDBC驅動,在jsp頁面透過request取得後台Servlet(Page.jsp)的轉送結果("result"),結合頁面屬性(PageProperties. java類)即可實現效果。 當然,這也是因為個人學習,傾向於多用點東西。 希望本文所述對大家jsp程式設計有幫助。 更多jsp+servlet+javabean實現資料分頁方法完整實例相關文章請關注PHP中文網!