zoukankan      html  css  js  c++  java
  • JSP数据库操作(JDBCODBC) 分页显示

      为了实现JSP数据库操作的实例,建立了一个MS SQLServer7数据库 DNS,名称为:Test_DB

    数据库中有一个表:guestbook字段为:name(varchar),email(varchar),body(text)

    数据库用户为sa 密码空,可以自己修改的。

      

        < %@ page contentType="text/html;charset=gb2312"%> 
    < %
    //变量声明
    java.sql.Connection sqlCon; //数据库连接对象
    java.sql.Statement sqlStmt; //SQL语句对象
    java.sql.ResultSet sqlRst; //结果集对象
    java.lang.String strCon; //数据库连接字符串
    java.lang.String strSQL; //SQL语句
    int intPageSize; //一页显示的记录数
    int intRowCount; //记录总数
    int intPageCount; //总页数
    int intPage; //待显示页码
    java.lang.String strPage;
    int i,j,k; //设置一页显示的记录数
    intPageSize = 5; //取得待显示页码
    strPage = request.getParameter("page");
    if(strPage==null){
    //表明在QueryString中没有page这一个参数,此时显示第一页数据
    intPage = 1;
    } else{
    //将字符串转换成整型
    intPage = java.lang.Integer.parseInt(strPage);
    if(intPage< 1) intPage = 1; }
    //装载JDBC-ODBC驱动程序
    Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
    //设置数据库连接字符串
    strCon = "jdbc:odbc:Test_DB";
    //连接数据库
    sqlCon = java.sql.DriverManager.getConnection(strCon,"sa","");
    //创建SQL语句对象
    sqlStmt = sqlCon.createStatement();
    //获取记录总数
    strSQL = "select count(*) from guestbook";
    sqlRst = sqlStmt.executeQuery(strSQL);
    //执行SQL语句并取得结果集
    sqlRst.next(); //记录集刚打开的时候,指针位于第一条记录之前
    intRowCount = sqlRst.getInt(1);
    sqlRst.close(); //关闭结果集
    //记算总页数
    intPageCount = (intRowCount+intPageSize-1) / intPageSize;
    //调整待显示的页码 if(intPage>intPageCount) intPage = intPageCount;
    //设置获取数据SQL语句
    strSQL = "select name,email,body from guestbook";
    //执行SQL语句并取得结果集
    sqlRst = sqlStmt.executeQuery(strSQL);
    //将记录指针定位到待显示页的第一条记录上
    i = (intPage-1) * intPageSize;
    for(j=0;j< i;j++) sqlRst.next(); %>
    < html>
    < head>
    < title>JSP数据库操作例程 - 数据分页显示 - JDBC-ODBC< /title>
    < /head>
    < body>
    < p align=center>jdbc-odbc留言版< /p>
    < table border="1" cellspacing="0" cellpadding="0" width=600 align=center>
    < %
    //显示数据
    i = 0;
    while(i< intPageSize && sqlRst.next()){ %>
    < tr>
    < td>姓名:< %=sqlRst.getString(1)%>< /td>
    < td>邮件:< %=sqlRst.getString(2)%>< /td>
    < /tr>
    < tr>
    < td colspan=2>< %=sqlRst.getString(3)%>< /td>
    < /tr>
    < % i++; } %>
    < tr>
    < td colspan=2 align=center>
    第< %=intPage%>页 共< %=intPageCount%>页
    < %if(intPage< intPageCount){%>
    < a href="mssql.jsp?page=< %=intPage+1%>">下一页< /a>< %
    }
    %>
    < %if(intPage>1){%>
    < a href="mssql.jsp?page=< %=intPage-1%>">上一页< /a>< %
    }
    %>
    < /td>
    < /tr>
    < /table> < /body>
    < /html>
    < %
    //关闭结果集
    sqlRst.close();
    //关闭SQL语句对象
    sqlStmt.close();
    //关闭数据库
    sqlCon.close();
    %>

    如何运行JSP数据库操作?

    将代码存为文件test.jsp

    Orion Application Server下:

    Copy到orion的default-web-app目录下,通过:

        http://localhost:port/test.jsp 
    

    访问测试
    对于Resin,Tomcat,JWS等等,都可以运行通过。JSP数据库操作到此完成。

  • 相关阅读:
    树状数组进阶
    洛谷 P2824 [HEOI2016/TJOI2016]排序
    抽象类
    关于getClass()和instanceof的区别与联系
    Java中的强制类型转换
    Java中的内联
    Java关键字之final
    Java中的"is-a"规则
    关于虚方法
    Java中的动态绑定
  • 原文地址:https://www.cnblogs.com/javadu/p/2262334.html
Copyright © 2011-2022 走看看