濮阳杆衣贸易有限公司

主頁 > 知識庫 > Jsp真分頁實例---分頁

Jsp真分頁實例---分頁

熱門標簽:電銷機器人免培訓(xùn) 外呼系統(tǒng)使用方法 如何看懂地圖標注點 自繪地圖標注數(shù)據(jù) 海外圖書館地圖標注點 電話機器人需要使用網(wǎng)絡(luò)嗎 潤滑油銷售電銷機器人 南通通訊外呼系統(tǒng)產(chǎn)品介紹 給地圖標注得傭金

網(wǎng)頁的分頁功能的實現(xiàn)比較簡單,實現(xiàn)方法也多種多樣。

今天總結(jié)一個簡單的Jsp真分頁實例。

首先,提到分頁就要先明確一個概念,何為真分頁何謂假分頁。

假分頁:一次性從數(shù)據(jù)庫讀出表的所有數(shù)據(jù)一次性的返回給客戶端,由js來控制每一頁的顯示。

真分頁:由程序控制,每一次只返回一頁大小的數(shù)據(jù),顯示到客戶端。

由此可以很清楚的分辨出真假分頁各自的優(yōu)缺點:

假分頁:由于一次性讀出所有數(shù)據(jù)并返回給客戶端,如果數(shù)據(jù)量龐大,所以這一次的動作可能是非常消耗服務(wù)器資源和帶寬的,

但是返回給客戶端以后就非常輕松了,客戶在一段時間內(nèi)不會再像服務(wù)器端請求資源。但不代表可能出現(xiàn)一些意外情況,

比如說客戶將瀏覽器關(guān)閉,重新訪問網(wǎng)站等。所以,如果數(shù)據(jù)量相當(dāng)龐大,不建議使用用真分頁。

真分頁:假分頁每次只取需要的數(shù)據(jù)返回給客戶端,比起真分頁沒有那么大的數(shù)據(jù)庫壓力。但也因為這個工作特性,所以假分頁

的方法需要頻繁和服務(wù)器端進行交互。既然頻繁交互,自然也會給服務(wù)器帶來負擔(dān)。

綜上:如果數(shù)據(jù)量較小,使用假分頁的效果會更優(yōu),如果數(shù)據(jù)量龐大,使用真分頁的效果更優(yōu)。

分析完特性,下面就來列舉一個簡單的真分頁實例。

真分頁是通過程序來控制的,每次向數(shù)據(jù)庫請求需要的數(shù)據(jù)。

簡述實現(xiàn)思路業(yè)務(wù)流程:

首先:客戶端帶著page參數(shù)請求客戶端,若沒有帶page參數(shù),說明是第一次訪問,則page參數(shù)默認為0;

其次:服務(wù)端根據(jù)page參數(shù),調(diào)用相關(guān)函數(shù),從數(shù)據(jù)庫中取出表中數(shù)據(jù),封裝成相關(guān)對象,返回給客戶端,并且返回新page參數(shù)及總頁數(shù);

最后:再客戶端顯示請求的相關(guān)數(shù)據(jù),并根據(jù)page參數(shù)及總頁數(shù)兩個參數(shù),決定上一頁下一頁的按鈕是否可用。

數(shù)據(jù)庫操作類:

public class DBBean {
  private Connection con;

  private PreparedStatement pstmt;
  private ResultSet rs;
  private String dbName ="test";
  private String dbuser = "root";
  private String dbpass ="******";
  
  static{
    try{
      Class.forName("com.mysql.jdbc.Driver");
    }catch(ClassNotFoundException e){
      System.out.println(e);
    }
    
  }
  
  public void prepareConnection(){
    try{
      con=DriverManager.getConnection("jdbc:mysql://localhost:3306/"+dbName,dbuser,dbpass);
    }catch(SQLException e){
      System.out.println(e);
    }
  }
  //關(guān)閉連接
  public void close(){
      try {
        if(con!=null)
          con.close();
      } catch (SQLException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
      }
      con = null;
      try {
        if(pstmt!=null)
          pstmt.close();
      } catch (SQLException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
      }
      pstmt = null;
  }
  //設(shè)置參數(shù)
  private void setParems(String[] parems){
    if(parems!=null){
      for(int i=0;iparems.length;i++){
        try {
          pstmt.setString(i+1, parems[i]);
        } catch (SQLException e) {
          // TODO Auto-generated catch block
          e.printStackTrace();
        }
      }
    }
  }
  public ResultSet executeQuery(String sql,String[] parems){
    ResultSet res = null;
    prepareConnection();
    try {
      pstmt = con.prepareStatement(sql);
      setParems(parems);
      res = pstmt.executeQuery();
    } catch (SQLException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
    }finally{
     }
    return res;
  }
}

學(xué)生類:

public class StudentBean {
  private long id;
  private String name;
  private String phone;
  private int age;
  private int score;
  public long getId() {
    return id;
  }
  public void setId(long id) {
    this.id = id;
  }
  public String getName() {
    return name;
  }
  public void setName(String name) {
    this.name = name;
  }
  public String getPhone() {
    return phone;
  }
  public void setPhone(String phone) {
    this.phone = phone;
  }
  public int getAge() {
    return age;
  }
  public void setAge(int age) {
    this.age = age;
  }
  public int getScore() {
    return score;
  }
  public void setScore(int score) {
    this.score = score;
  }
}

學(xué)生數(shù)據(jù)操作類

public class StudentDao implements StudentDaoIn {
@Override 
public ArrayListStudentBean> findByPage(int page){
    DBBean db = new DBBean();
    int begin = (page-1) * 5;
    String sql = "select * from t_student limit "+begin+",5";
    ResultSet rs = db.executeQuery(sql,null);
    ArrayListStudentBean> list = new ArrayListStudentBean>();
    try {
      while(rs.next()){
        StudentBean st = new StudentBean();
        st.setName(rs.getString("name"));
        st.setAge(rs.getInt("age"));
        st.setId(rs.getInt("id"));
        st.setPhone(rs.getString("phnoe"));
        st.setScore(rs.getInt("score"));
        list.add(st);
      }
    } catch (SQLException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
    }
    return list;
  }
  @Override 
  public int userCount(){
    DBBean db = new DBBean();
    String sql = "select count(*) from t_student";
    ResultSet rs = db.executeQuery(sql, null);
    int count = 0;
    try {
      rs.next();
      count = rs.getInt(1);
    } catch (SQLException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
    }
    return count;
  }
}

相關(guān)業(yè)務(wù)邏輯

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    // TODO Auto-generated method stub
    String page = null;
    page = request.getParameter("page");
    if(page == null || page=="")
      page = "1";
    StudentDao studao = new StudentDao();
    request.setAttribute("student",studao.findByPage(Integer.parseInt(page)));
    request.setAttribute("pagenum",studao.userCount()/5+1);//總頁數(shù)
    request.setAttribute("page", page);//當(dāng)前頁
    request.getRequestDispatcher("student.jsp").forward(request, response);  
    
  }

前臺JSP代碼:

table id="t_stu" border="1" cellpadding="2" cellspacing="0">
  thead>
    tr>
      th>ID/th>
      th>姓名/th>
      th>年齡/th>
      th>電話/th>
      th>成績/th>
    /tr>
  /thead>
  c:forEach items="${student}" var="st">
    tr>
      td>${st.getId()}/td>
      td>${st.getName()}/td>
      td>${st.getAge()}/td>
      td>${st.getPhone()}/td>
      td>${st.getScore()}/td>
    /tr>
  /c:forEach>
/table>
br>
共 ${pagenum}頁  當(dāng)前 第${page}頁 
c:choose>
  c:when test="${page>1}">
    a href="getSutent?page=${page-1}" rel="external nofollow" >input type="button" value="上一頁" >/a>
  /c:when>
  c:otherwise>
    input type="button" value="上一頁" disabled="disabled" />
  /c:otherwise>
/c:choose>
c:choose>
  c:when test="${page!=pagenum}">
    a href="getSutent?page=${page+1}" rel="external nofollow" >input type="button" value="下一頁">/a>
  /c:when>
  c:otherwise>
    input type="button" value="下一頁" disabled="disabled" />
  /c:otherwise>
/c:choose>

本例是真分頁的一個簡單實現(xiàn),有著明顯的缺點。

例如:

1.在后臺相關(guān)業(yè)務(wù)邏輯處,只對page做了簡單的判斷,因為查詢相關(guān)page時,參數(shù)是寫入前臺a標簽中的,所以懂技術(shù)的用戶,可以隨意改動其值

由此查詢數(shù)據(jù)庫可能帶來意想不到的錯誤。

2.功能不夠完善,僅提供了上一頁下一頁按鈕的簡單功能。

另外:實現(xiàn)假分頁時可以結(jié)合ajax和json。以此可實現(xiàn)無刷新翻頁,看起來功能和真分頁一樣。。。

您可能感興趣的文章:
  • jsp分頁顯示的實現(xiàn)代碼
  • JSP分頁顯示的實例代碼
  • jsp實現(xiàn)上一頁下一頁翻頁功能(示例代碼)

標簽:大連 廣州 樂山 南京 黃石 貸款邀約 銅川 內(nèi)江

巨人網(wǎng)絡(luò)通訊聲明:本文標題《Jsp真分頁實例---分頁》,本文關(guān)鍵詞  Jsp,真,分頁,實例,---分頁,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Jsp真分頁實例---分頁》相關(guān)的同類信息!
  • 本頁收集關(guān)于Jsp真分頁實例---分頁的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    桃园县| 若尔盖县| 永顺县| 夏河县| 荣昌县| 儋州市| 张家港市| 金寨县| 湘西| 班戈县| 东乡县| 麻栗坡县| 庄河市| 台山市| 本溪| 于都县| 贵港市| 横山县| 景宁| 兴隆县| 陵川县| 孝义市| 阿拉善右旗| 克拉玛依市| 沽源县| 易门县| 新乡市| 永嘉县| 辽宁省| 平安县| 凤庆县| 株洲市| 东港市| 安岳县| 扶沟县| 长丰县| 吉安市| 兴安县| 丹凤县| 房山区| 晋城|