亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JSP > 正文

servlet分頁代碼示例

2020-07-27 21:35:07
字體:
來源:轉載
供稿:網友

1.首先創建一個對象 UserData,用以保存從數據庫中獲取的數據。

復制代碼 代碼如下:

package com.tool;

import java.math.BigDecimal;
import java.util.Date;

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

    /**
     * EMP表中的數據屬性
     */
    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.創建一個 DBHelper 對象用以與數據庫進行交互

復制代碼 代碼如下:

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;  //數據庫連接對象
    PreparedStatement pt;  //SQL語句預處理對象
    ResultSet rs;  //結果集對象

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

    /**
     * 獲取當前頁的數據
     * @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()){
                /**
                 * 從結果集中取得數據
                 */
                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");
                /**
                 * 設置對象屬性
                 */
                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);  //把對象添加集合中
            }
            rs.close();
            pt.close();
            conn.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return dataList;
    }

    /**
     * 返回總頁數
     * @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");  //創建數據庫連接
            String sql = "select count(*) from emp";
            pt = conn.prepareStatement(sql);
            rs = pt.executeQuery();
            if (rs.next()){
                maxRowCount = rs.getInt(1);  //總行數
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
        maxPage = (maxRowCount + rowsPerPage - 1) / rowsPerPage;  //總頁數
        return maxPage;
    }
}

3.創建 Servlet 對顯示頁面進行控制

復制代碼 代碼如下:

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;  //每頁顯示的行數
    public int curPage;  //當前頁頁碼
    public int maxPage;  //總共頁數
    DBHelper db = new DBHelper();
    public Servlet(){
        rowsPerPage = 5;
    }

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

        List<UserData> dataList;
        dataList = db.getData(curPage,rowsPerPage);  //獲取當前頁的數據
        maxPage = db.getMaxPage(rowsPerPage);  //獲取總頁數
        request.setAttribute("dataList",dataList);
        request.setAttribute("maxPage", maxPage);

        RequestDispatcher rd = request.getRequestDispatcher("pagemain.jsp");  //將請求轉發到pagemain.jsp頁面
        rd.forward(request,response);
    }

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

4.創建 JSP 頁面,顯示數據。

復制代碼 代碼如下:

<%@ page import="java.util.List" %>
<%@ page import="com.tool.UserData" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>servlet數據分頁</title>
    <link rel="stylesheet" type="text/css" href="css.css">
</head>
<body>
<div style="margin-top: 15%; margin-left: 25%">
    <table>
        <caption>SCOTT用戶,EMP表中的數據</caption>
        <%! int curPage,maxPage; %>
        <% curPage =Integer.parseInt(request.getAttribute("curPage").toString()); %> <!--取得當前頁-->
        <% maxPage =Integer.parseInt((String)request.getAttribute("maxPage").toString()); %> <!--取得總頁數-->
        <%if (request.getAttribute("dataList") == null){
        %>
        <tr>
            <td colspan="8">沒有數據</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>
            <!--取得表中數據-->
            <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 %>頁,共<%= maxPage %>頁&nbsp;&nbsp;
    <%if (curPage > 1){
    %>
    <a href="Servlet?page=1">首頁</a>
    <a href="Servlet?page=<%=curPage - 1%>">上一頁</a>
    <%
    }else {
    %>
    首頁 上一頁
    <%
        }%>
    <%if (curPage < maxPage){
    %>&nbsp;&nbsp;
    <a href="Servlet?page=<%=curPage + 1%>">下一頁</a>
    <a href="Servlet?page=<%=maxPage %>">尾頁</a>
    <%
    }else {
    %>
    下一頁 尾頁
    <%
        }%>
    &nbsp;&nbsp;轉至第&nbsp;<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){
            %>
            <!--當前頁頁碼默認選中-->
            <option selected value="<%= i%>"><%= i %></option>
            <%
            }else {
            %>
            <option value="<%= i %>"><%= i %></option>
            <%
                    }
                }%>
        </select>
    </label>
</form>&nbsp;頁
</div>
</body>
</html>

web.xml 中的配置文件為:

復制代碼 代碼如下:

<?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>

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲第一色在线| 欧美乱人伦中文字幕在线| 欧美精品精品精品精品免费| 亚洲欧美日韩直播| 中文字幕久热精品在线视频| 亚洲色图欧美制服丝袜另类第一页| 91久久国产综合久久91精品网站| 伊人久久免费视频| 久久久久久久爱| 在线播放日韩av| 97在线视频国产| 欧美野外wwwxxx| 色香阁99久久精品久久久| 久久精品久久精品亚洲人| 亚洲а∨天堂久久精品喷水| 亚洲欧美日韩精品久久| 亚洲xxxx在线| 久久久久久久影院| 久久久欧美精品| 欧美成人精品在线视频| 亚洲成人精品在线| 精品国产乱码久久久久久天美| 欧美高清在线播放| 日韩中文字幕视频在线| 国产精品专区第二| 国产精品www网站| 亚洲色图35p| 一本色道久久88亚洲综合88| 青青久久av北条麻妃黑人| 国产精品第一区| 亚洲欧洲一区二区三区久久| 亚洲人成电影在线播放| 中文字幕精品一区久久久久| 亚洲天堂av在线播放| 国产精品九九九| 亚洲91av视频| 国模极品一区二区三区| 欧美另类高清videos| 91中文在线视频| 国产精品美女www爽爽爽视频| 久久精品99久久久香蕉| 成人国产精品久久久久久亚洲| 日韩精品中文字| 一区二区三区四区在线观看视频| 亚洲精品国产精品乱码不99按摩| 日韩av免费在线播放| 91中文字幕一区| 国产午夜精品麻豆| 97久久精品视频| 亚洲欧美国产精品久久久久久久| 国产成人啪精品视频免费网| 亚洲国产精品专区久久| 欧美性生交xxxxxdddd| 久久久久久亚洲| 欧美成人三级视频网站| 亚洲专区国产精品| 亚洲片国产一区一级在线观看| 欧美视频在线观看 亚洲欧| 97在线精品视频| 欧美性猛交xxxx富婆| 97国产精品人人爽人人做| 乱亲女秽乱长久久久| 日韩在线观看高清| 久久国产精品视频| 精品国产精品三级精品av网址| 午夜精品蜜臀一区二区三区免费| 在线精品播放av| 在线观看日韩专区| 国产日韩中文字幕在线| 精品国内产的精品视频在线观看| 亚洲第一福利视频| 欧美日韩一区二区精品| 都市激情亚洲色图| 国产精品无码专区在线观看| 久久天天躁夜夜躁狠狠躁2022| 亚洲精品短视频| 久久理论片午夜琪琪电影网| 亚洲一区二区三区视频播放| 亚洲精品福利资源站| 国产精品视频1区| 亚洲欧美色婷婷| 高清一区二区三区日本久| 国产日韩精品在线播放| 国产日韩亚洲欧美| 国产精品久久久久久久久久久久久| 欧美国产高跟鞋裸体秀xxxhd| 久久激情视频免费观看| 国产精品一区二区久久精品| 亚洲最大成人免费视频| 亚洲欧美制服中文字幕| 日韩av快播网址| 欧美色道久久88综合亚洲精品| 日本午夜人人精品| 欧美午夜精品在线| 91久久久久久国产精品| 97久久精品视频| 另类少妇人与禽zozz0性伦| 最近2019好看的中文字幕免费| 日韩av成人在线| 日韩欧美aⅴ综合网站发布| 5566日本婷婷色中文字幕97| 亚洲www在线观看| 亚洲人成在线电影| 在线精品视频视频中文字幕| 91在线视频免费| 国产一区二区丝袜高跟鞋图片| 国产美女久久精品香蕉69| 欧美一区二区大胆人体摄影专业网站| 91视频8mav| 成人免费网站在线看| 国产精品久久久久久久久久久新郎| 欧美一区二区三区精品电影| 国产精品免费久久久久影院| 国产精品视频在线观看| 亚洲福利视频久久| 久久国产一区二区三区| 国产视频久久久| 性色av一区二区三区免费| 91久久精品一区| 国产成人精品免高潮在线观看| 欧美孕妇毛茸茸xxxx| 国产精品中文字幕在线观看| 欧美国产亚洲精品久久久8v| 国产精品美女999| 日韩视频免费在线观看| 国产欧美va欧美va香蕉在线| 97色伦亚洲国产| 国产精品欧美一区二区三区奶水| 亚洲电影免费观看高清完整版| 欧美国产欧美亚洲国产日韩mv天天看完整| 国内精品久久久久影院 日本资源| 国产精品高清免费在线观看| 综合网日日天干夜夜久久| 欧美综合在线第二页| 粗暴蹂躏中文一区二区三区| 久久久99免费视频| 91av免费观看91av精品在线| 日韩在线激情视频| 欧美多人乱p欧美4p久久| 欧美日韩国产成人在线观看| 亚洲欧美另类自拍| 欧美激情二区三区| 国产欧美精品日韩| www国产精品com| 日韩在线精品视频| 国产在线精品播放| 亚洲理论片在线观看| 久久久久久久久国产| 色哟哟亚洲精品一区二区| 欧美成人手机在线| 91在线观看免费观看| 亚洲欧洲日本专区| 91久久国产综合久久91精品网站| 亚洲欧美日韩一区二区在线| 亚洲人成人99网站| 日韩欧美精品在线观看| 国产一区玩具在线观看| 青草青草久热精品视频在线网站| 亚洲欧美日韩在线一区| 中文字幕九色91在线| 成人久久一区二区| 91国内免费在线视频| 国产999精品久久久影片官网| 欧美国产精品日韩|