一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

servlet分頁(yè)代碼示例

1.首先創(chuàng)建一個(gè)對(duì)象 UserData,用以保存從數(shù)據(jù)庫(kù)中獲取的數(shù)據(jù)。

復(fù)制代碼 代碼如下:
package com.tool;

import Java.math.BigDecimal;
import Java.util.Date;

/**
 * Created by lx_sunwei on 14-1-6.
 */
public class UserData {

    /**
     * EMP表中的數(shù)據(jù)屬性
     */
    private String ename;
    private String job;
    private BigDecimal empno;
    private BigDecimal mgr;
    private Date hireDate;
    private BigDecimal sal;
    private BigDecimal comm;
    private BigDecimal deptno;

    public BigDecimal getEmpno() {
        return empno;
    }

    public void setEmpno(BigDecimal empno) {
        this.empno = empno;
    }

    public BigDecimal getMgr() {
        return mgr;
    }

    public void setMgr(BigDecimal mgr) {
        this.mgr = mgr;
    }

    public Date getHireDate() {
        return hireDate;
    }

    public void setHireDate(Date hireDate) {
        this.hireDate = hireDate;
    }

    public BigDecimal getSal() {
        return sal;
    }

    public void setSal(BigDecimal sal) {
        this.sal = sal;
    }

    public BigDecimal getComm() {
        return comm;
    }

    public void setComm(BigDecimal comm) {
        this.comm = comm;
    }

    public BigDecimal getDeptno() {
        return deptno;
    }

    public void setDeptno(BigDecimal deptno) {
        this.deptno = deptno;
    }

    public String getEname() {
        return ename;
    }

    public void setEname(String ename) {
        this.ename = ename;
    }

    public String getJob() {
        return job;
    }

    public void setJob(String job) {
        this.job = job;
    }
}

2.創(chuàng)建一個(gè) DBHelper 對(duì)象用以與數(shù)據(jù)庫(kù)進(jìn)行交互

復(fù)制代碼 代碼如下:
package com.dao;

import com.tool.UserData;

import Java.math.BigDecimal;
import Java.sql.*;
import Java.util.*;
import Java.util.Date;

/**
 * Created by lx_sunwei on 14-1-6.
 */
public class DBHelper {

    Connection conn;  //數(shù)據(jù)庫(kù)連接對(duì)象
    PreparedStatement pt;  //SQL語(yǔ)句預(yù)處理對(duì)象
    ResultSet rs;  //結(jié)果集對(duì)象

    public  DBHelper(){
        try {
            Class.forName("oracle.jdbc.driver.OracleDriver");  //裝載驅(qū)動(dòng)
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        }
    }

    /**
     * 獲取當(dāng)前頁(yè)的數(shù)據(jù)
     * @param curPage
     * @param rowsPerPage
     * @return
     */
    public List<UserData> getData(int curPage, int rowsPerPage) {

        List<UserData> dataList = new ArrayList<>();
        String url = "jdbc:oracle:thin:@localhost:1521:orcl";
        try {
            conn = DriverManager.getConnection(url,"scott","tiger");
            String sql = "select * from emp where rownum <= ((? - 1) * "+rowsPerPage+" + "+rowsPerPage+") minus " +
                    " select * from emp where rownum <= (? - 1) * "+rowsPerPage+" ";
            pt = conn.prepareStatement(sql);
            pt.setInt(1,curPage);
            pt.setInt(2,curPage);
            rs = pt.executeQuery();
            while (rs.next()){
                /**
                 * 從結(jié)果集中取得數(shù)據(jù)
                 */
                UserData userData = new UserData();
                BigDecimal empno = rs.getBigDecimal("empno");
                String ename = rs.getString("ename");
                String job = rs.getString("job");
                BigDecimal mgr = rs.getBigDecimal("mgr");
                Date hireDate = rs.getDate("hiredate");
                BigDecimal sal = rs.getBigDecimal("sal");
                BigDecimal comm = rs.getBigDecimal("comm");
                BigDecimal deptno = rs.getBigDecimal("deptno");
                /**
                 * 設(shè)置對(duì)象屬性
                 */
                userData.setEmpno(empno);
                userData.setEname(ename);
                userData.setJob(job);
                userData.setMgr(mgr);
                userData.setHireDate(hireDate);
                userData.setSal(sal);
                userData.setComm(comm);
                userData.setDeptno(deptno);
                dataList.add(userData);  //把對(duì)象添加集合中
            }
            rs.close();
            pt.close();
            conn.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return dataList;
    }

    /**
     * 返回總頁(yè)數(shù)
     * @return
     */
    public int getMaxPage(int rowsPerPage) {
        int maxPage;
        int maxRowCount = 0;
        String url = "jdbc:oracle:thin:@localhost:1521:orcl";
        try {
            conn = DriverManager.getConnection(url,"scott","tiger");  //創(chuàng)建數(shù)據(jù)庫(kù)連接
            String sql = "select count(*) from emp";
            pt = conn.prepareStatement(sql);
            rs = pt.executeQuery();
            if (rs.next()){
                maxRowCount = rs.getInt(1);  //總行數(shù)
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
        maxPage = (maxRowCount + rowsPerPage - 1) / rowsPerPage;  //總頁(yè)數(shù)
        return maxPage;
    }
}

3.創(chuàng)建 Servlet 對(duì)顯示頁(yè)面進(jìn)行控制

復(fù)制代碼 代碼如下:
package com.servlet;

import com.dao.DBHelper;
import com.tool.UserData;

import Javax.servlet.RequestDispatcher;
import Javax.servlet.ServletException;
import Javax.servlet.http.HttpServlet;
import Javax.servlet.http.HttpServletRequest;
import Javax.servlet.http.HttpServletResponse;
import Java.io.IOException;
import Java.util.*;

/**
 * Created by lx_sunwei on 14-1-6.
 */
public class Servlet extends HttpServlet {

    public int rowsPerPage;  //每頁(yè)顯示的行數(shù)
    public int curPage;  //當(dāng)前頁(yè)頁(yè)碼
    public int maxPage;  //總共頁(yè)數(shù)
    DBHelper db = new DBHelper();
    public Servlet(){
        rowsPerPage = 5;
    }

    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        String curPage1 = request.getParameter("page");  //獲取當(dāng)前頁(yè)頁(yè)碼
        if (curPage1 == null){
            curPage = 1;
            request.setAttribute("curPage",curPage);  //設(shè)置curPage對(duì)象
        }else {
            curPage = Integer.parseInt(curPage1);
            if (curPage < 1){
                curPage = 1;
            }
            request.setAttribute("curPage",curPage);
        }

        List<UserData> dataList;
        dataList = db.getData(curPage,rowsPerPage);  //獲取當(dāng)前頁(yè)的數(shù)據(jù)
        maxPage = db.getMaxPage(rowsPerPage);  //獲取總頁(yè)數(shù)
        request.setAttribute("dataList",dataList);
        request.setAttribute("maxPage", maxPage);

        RequestDispatcher rd = request.getRequestDispatcher("pagemain.jsp");  //將請(qǐng)求轉(zhuǎn)發(fā)到pagemain.jsp頁(yè)面
        rd.forward(request,response);
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doPost(request,response);
    }
}

4.創(chuàng)建 JSP 頁(yè)面,顯示數(shù)據(jù)。

復(fù)制代碼 代碼如下:
<%@ page import="Java.util.List" %>
<%@ page import="com.tool.UserData" %>
<%@ page contentType="text/html;charset=UTF-8" language="Java" %>
<html>
<head>
    <title>servlet數(shù)據(jù)分頁(yè)</title>
    <link rel="stylesheet" type="text/css" href="css.css">
</head>
<body>
<div style="margin-top: 15%; margin-left: 25%">
    <table>
        <caption>SCOTT用戶,EMP表中的數(shù)據(jù)</caption>
        <%! int curPage,maxPage; %>
        <% curPage =Integer.parseInt(request.getAttribute("curPage").toString()); %> <!--取得當(dāng)前頁(yè)-->
        <% maxPage =Integer.parseInt((String)request.getAttribute("maxPage").toString()); %> <!--取得總頁(yè)數(shù)-->
        <%if (request.getAttribute("dataList") == null){
        %>
        <tr>
            <td colspan="8">沒(méi)有數(shù)據(jù)</td>
        </tr>
        <%
        }else {
        %>
        <tr>
            <!--表頭-->
            <th>EMPNO</th>
            <th>ENAME</th>
            <th>JOB</th>
            <th>MGR</th>
            <th>HIREDATE</th>
            <th>SAL</th>
            <th>COMM</th>
            <th>DEPTNO</th>
        </tr>
        <%
            List list = (List) request.getAttribute("dataList");
            for (Object aList : list) {
                UserData userData = (UserData) aList;
        %>
        <tr>
            <!--取得表中數(shù)據(jù)-->
            <td><%= userData.getEmpno() %></td>
            <td><%= userData.getEname() %></td>
            <td><%= userData.getJob() %></td>
            <td><%= userData.getMgr() %></td>
            <td><%= userData.getHireDate() %></td>
            <td><%= userData.getSal() %></td>
            <td><%= userData.getComm() %></td>
            <td><%= userData.getDeptno() %></td>
        </tr>
        <%
                }
            }
        %>
    </table>
</div>
<div style="margin-top: 8%; margin-left: 29%">
    第<%= curPage %>頁(yè),共<%= maxPage %>頁(yè)  
    <%if (curPage > 1){
    %>
    <a href="Servlet?page=1">首頁(yè)</a>
    <a href="Servlet?page=<%=curPage - 1%>"></a>
    <%
    }else {
    %>
    首頁(yè)
    <%
        }%>
    <%if (curPage < maxPage){
    %>  
    <a href="Servlet?page=<%=curPage + 1%>"></a>
    <a href="Servlet?page=<%=maxPage %>">尾頁(yè)</a>
    <%
    }else {
    %>
    尾頁(yè)
    <%
        }%>
      轉(zhuǎn)至第 <form name="form1" action="Servlet" method="get">
    <label>
        <select name="page" onchange="document.form1.submit()">
            <%for ( int i = 1; i <= maxPage; i++){
                if (i == curPage){
            %>
            <!--當(dāng)前頁(yè)頁(yè)碼默認(rèn)選中-->
            <option selected value="<%= i%>"><%= i %></option>
            <%
            }else {
            %>
            <option value="<%= i %>"><%= i %></option>
            <%
                    }
                }%>
        </select>
    </label>
</form> 頁(yè)
</div>
</body>
</html>

web.xml 中的配置文件為:

復(fù)制代碼 代碼如下:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://Java.sun.com/xml/ns/Javaee"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
           xsi:schemaLocation="http://Java.sun.com/xml/ns/Javaee
          http://Java.sun.com/xml/ns/Javaee/web-app_3_0.xsd"
           version="3.0">

    <servlet>
        <servlet-name>Servlet</servlet-name>
        <servlet-class>com.servlet.Servlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>Servlet</servlet-name>
        <url-pattern>/Servlet</url-pattern>
    </servlet-mapping>

</web-app>

把項(xiàng)目部署到 Tomcat 服務(wù)器上,輸入地址:http://localhost:8080/Servlet   這樣就可以看到效果

jsp技術(shù)servlet分頁(yè)代碼示例,轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产91原创| 国产综合在线观看视频 | 亚洲毛片大全 | 欧美第一页草草影院浮力 | 黄色长视频 | www.欧美激情 | 韩国免费乱理论片在线观看2018 | 成人春色在线观看免费网站 | 国产福利合集 | 免费观看成人鲁鲁鲁鲁鲁视频 | 岛国欧美| 一区二区三区视频免费 | 自偷自偷自亚洲首页精品 | 婷婷涩涩 | 福利91| 夜福利视频 | 日韩美女强理论片 | 亚洲精品tv久久久久久久久久 | 美女色哟哟| 国产精品嫩草影院在线观看免费 | 亚洲人成图片欧美人成图片 | 精品精品国产自在久久高清 | 9久久免费国产精品特黄 | 亚洲小色网 | 色综合天天综久久久噜噜噜久久〔 | 婷婷亚洲激情 | 婷婷六月丁香午夜爱爱 | 国产四虎免费精品视频 | 97青草香蕉依人在线播放 | 国产一区二区视频在线观看 | 在线视频一区二区 | 97青草香蕉依人在线播放 | 黄 色 免 费 网站在线观看 | 亚洲女人在线 | 国产成人自啪精品视频 | 亚洲成a人片777777网站 | 韩国美女爽快一级毛片黄 | 中文字幕一区二区三区在线观看 | 午夜爽视频 | 污视频免费在线播放 | 天天色天天射综合网 |