• oracle中实现分页(servlet 实现)


    文章出自:http://blog.csdn.net/zklxuankai/article/details/7604474

    package com.xk.view;


    import java.io.IOException;
    import java.io.PrintWriter;
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.PreparedStatement;
    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;

    public class ManagerUsers extends HttpServlet
    {
        @Override
        protected void doGet(HttpServletRequest req, HttpServletResponse resp)
                throws ServletException, IOException
        {
            resp.setContentType("text/html;charset=utf-8");
            PrintWriter out = resp.getWriter();
            
             Connection ct = null;
             PreparedStatement ps = null;
             ResultSet rs = null;

          //四个参数 : pageNow 当前所在页,pageSize 每页多少行, pageCount   总共有多少页, rowCount 总共用多少行记录

    //pageCount = rowCount%pageSize==0 ? rowCount/pageSize : (rowCount/pageSize+1);

             int pageNow =1;
             
             String spageNow = req.getParameter("pageNow");
             
             if(spageNow !=null)
             {
                 pageNow = Integer.parseInt(spageNow);

             }          

           

             int pageSize = 4;
             int rowCount = 1;       
            int pageCount = 1;
      

             try
             {
                 //1.加载驱动
                 Class.forName("oracle.jdbc.driver.OracleDriver");
                 //2.建立连接
                 ct = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:orcl","system","Oracle123");
                 //3.生成preparedstatement
                 
                 ps = ct.prepareStatement("select count(*) from scott.emp");
                 
                 rs = ps.executeQuery();
                 
                 rs.next();
                 
                 rowCount = rs.getInt(1); //得到总行数
                 
                 pageCount = rowCount%pageSize==0 ? rowCount/pageSize : (rowCount/pageSize+1);//得到记录的页的总数

                

    //分页计算 

                ps = ct.prepareStatement("select * from (select  t.*,  rownum rn from (select * from scott.emp order by empno) t where rownum <="+pageSize*pageNow+") where rn >="+(pageSize*(pageNow-1)+1));
                 //4.执行查询
                  
                 rs = ps.executeQuery();
            
                 out.println("<h1 align='center'>管理雇员</h1><hr/>");
                    out.println("<table border='1' bordercolor='green' cellsapcing=0 align='center' width='80%'><tr><th>账号</th><th>姓名</th>" +
                            "<th>工作</th><th>上级</th><th>雇用日期</th><th>薪水</th><th>加薪</th><th>部门</th>"
                            +"<th>修改用户</th><th>删除用户</th></tr>");
                 
                 while(rs.next())
                 {
                     
                     out.println("<tr><th>"+rs.getInt(1)+"</th><th>"+rs.getString(2)+"</th><th>"+rs.getString(3)
                             +"</th><th>"+rs.getInt(4)+"</th><th>"+rs.getDate(5)+"</th><th>"+rs.getInt(6)+
                             "</th><th>"+rs.getInt(7)+"</th><th>"+rs.getInt(8)+
                             "</th><th><font color='blue'>修改用户</font></th><th><font color='blue'>删除用户</font></th><tr>");
                     
                 }

                 out.println("</table>");
                
                 for(int i=1;i<=pageCount;i++)
                 {
                     out.println("<a href='/review/ManagerUsers?pageNow="+i+"'><"+i+"></a>");
                 }     

                 
             }
             catch(Exception e)
             {
                 e.printStackTrace();
             }
             finally
             {

                 //5.关闭资源 

    try
                    {

                        if(rs!=null){

       rs.close();

        }  

       if(rs!=null){

       rs.close();

        }

    if(rs!=null){

       rs.close();

        }

                    }
                    catch (SQLException e)
                    {
                        e.printStackTrace();
                    }        
               }     
        }
    }
  • 相关阅读:
    DataGrid数据格式设置表达式
    删除确认按钮
    获取CpuID
    R0~R31寄存器
    动态改变asp.net网页的标题
    使用"Infragistics"问题集
    Read Cpu Id
    操作DataRow记录
    用Javascript创建"后退"按钮
    日历控件的“星期几”变为“几”
  • 原文地址:https://www.cnblogs.com/tgxblue/p/4217426.html
Copyright © 2020-2023  润新知