jsp和JavaBean实现数据分页

java 代码
xml 代码
  1. package com.student.util.page;       
  2.       
  3. import java.sql.*;       
  4.       
  5.       
  6. public class DBcon{       
  7.     private String url="proxool.mytest";       
  8.     private String driver="org.logicalcobwebs.proxool.ProxoolDriver";       
  9.     Connection con=null;       
  10.     Statement stmt=null;       
  11.       
  12.     public DBcon () throws ClassNotFoundException, SQLException {       
  13.         Class.forName(driver);       
  14.         con=DriverManager.getConnection(url);       
  15.         stmt=con.createStatement(java.sql.ResultSet.TYPE_SCROLL_INSENSITIVE,java.sql.ResultSet.CONCUR_READ_ONLY);       
  16.            
  17.     }       
  18.       
  19.       
  20.     public Connection getCon() throws SQLException {       
  21.                
  22.         return con;       
  23.     }       
  24.     public void setCon(Connection con) {       
  25.         this.con = con;       
  26.     }       
  27.       
  28.       
  29.       
  30.     public Statement getStmt() {       
  31.         return stmt;       
  32.     }       
  33.       
  34.       
  35.     public void setStmt(Statement stmt) {       
  36.         this.stmt = stmt;       
  37.     }       
  38.       
  39.       
  40.       
  41.                
  42. }       
  43.       
  44.       
  45.       
  46. -----------------------------    
  47.   
  48. <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>  
  49. <%@ page import="java.sql.*" %>  
  50.   
  51. <jsp:useBean id="db" class="com.student.util.page.DBcon" ></jsp:useBean>  
  52. <jsp:setProperty property="con" name="db"/>  
  53. <jsp:setProperty property="stmt" name="db"/>    
  54.   
  55.  <br> <br> <br>  
  56.   
  57.   
  58.   
  59.  <%    
  60.   
  61. java.sql.ResultSet rs; //结果集对象    
  62.   
  63.   
  64. String sql; //SQL语句    
  65.   
  66. int pageSize; //一页显示的记录数    
  67. int RowCount; //记录总数    
  68. int PageCount; //总页数    
  69. int intPage; //待显示页码    
  70. String strPage;    
  71.   
  72. int i;    
  73.   
  74.   
  75. pageSize = 3;    
  76.   
  77.   
  78. strPage = request.getParameter("page");    
  79. if(strPage==null){//表明在QueryString中没有page这一个参数,此时显示第一页数据    
  80. intPage = 1;    
  81. }    
  82. else{   
  83. intPage = java.lang.Integer.parseInt(strPage);    
  84. if(intPage<1intPage = 1;    
  85. }    
  86.   
  87.   
  88. //连接数据库    
  89. db.getCon().createStatement();   
  90.   
  91. //创建一个可以滚动的只读的SQL语句对象    
  92. sql = "select * from teacher";    
  93.   
  94. rs=db.getStmt().executeQuery(sql);   
  95.   
  96.   
  97. rs.last();    
  98. RowCount = rs.getRow();    
  99.   
  100.   
  101. PageCount = (RowCount+pageSize-1) / pageSize;    
  102.   
  103.   
  104. if(intPage>PageCount) intPage = PageCount;    
  105. %>    
  106.   
  107.   
  108. <body>    
  109.   
  110. <table border="1" cellspacing="0" cellpadding="0" align="center">    
  111. <tr>    
  112. <th>姓名</th>    
  113. <th>爱好</th>    
  114. </tr>    
  115.   
  116. <%    
  117. if(PageCount>0){    
  118.   
  119. rs.absolute((intPage-1) * pageSize + 1);    
  120.   
  121. i = 0;    
  122. while(i<pageSize && !rs.isAfterLast()){    
  123. %>    
  124. <tr>    
  125. <td><%=rs.getString(1)%></td>    
  126. <td><%=rs.getString(2)%></td>    
  127.   
  128. </tr>    
  129. <%    
  130. rs.next();    
  131. i++;    
  132. }    
  133. }    
  134. %>    
  135.   
  136. </table>    
  137.   
  138.   
  139.   
  140.   
  141.   
  142. <p align="center">  
  143.  第 <input type="text" value="<%=intPage%>" size="1" style> 页   
  144.    共   
  145.    <font color="red" size=15>  
  146.    <%=PageCount%></font> 页 <br>  
  147.   
  148.  <%if(intPage<PageCount){%>  
  149.     
  150.   
  151.  <a href="partpage.jsp?page=<%=intPage+1%>">下一页</a>  
  152.      
  153.     
  154.  <%}%>    
  155.      
  156.   <%if(intPage>1){%><a href="partpage.jsp?page=<%=intPage-1%>">上一页</a>  
  157.   <a href="partpage.jsp?page=<%=intPage-intPage%>">首页</a>  
  158.      
  159.   <%}%>    
  160.   
  161. </p>  
  162.   
  163.   
  164.   
  165. <%    
  166. //关闭结果集    
  167. rs.close();    
  168.   
  169. //关闭SQL语句对象    
  170. db.getCon().close();    
  171. db.getStmt().close();   
  172. //关闭数据库    
  173.   
  174. %>  

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值