JSP - 分页

介绍

JavaServer Pages或 JSP 是一种基于 Java 的技术,用于创建动态网页。JSP 使用特殊的 JSP 标记帮助在 HTML 文件中插入 Java 代码。例如,显示前五个偶数的 JSP 页面将如下所示,

<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <title>JSP Page</title>
    </head>
    <style>
        body{
            padding: 50px;
        }
    </style>
    <body>
        <%
            for(int i=0;i<10;i++){
                if(i%2==0)
                    out.print("<h1>Even No: "+i+"</h1>");  
            }
        %>
    </body>
</html>

 

分页

假设我们的数据库中有多个记录。在这种情况下,我们使用分页将记录分解成更方便的可读位,对用户和处理器来说都是如此,因为具有多个记录的单个页面可能需要时间来加载并且用户可能会很累。让我们看一个分页的例子,

我们将在 Netbeans 中创建我们的项目,使用 XAMPP 服务器连接到我们的 SQL 数据库。以下是项目结构。

 

 

index.jsp

<%@page contentType="text/html" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <title>JSP Page</title>
    </head>
    <body>
        <a href="view.jsp?page=1">View Employees</a>  
    </body>
</html>

 

view.jsp

<%@page contentType="text/html" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <title>JSP Page</title>
    </head>
    <style>
        body{
            padding: 50px;
        }
    </style>
    <body>
        <%@ page import="java.util.*,Emp.*,EmpDao.*" %>  
        <%  
        String spageid=request.getParameter("page");  
        int pageid=Integer.parseInt(spageid);  
        int total=5;
        if(pageid!=1){  
            pageid=pageid-1;  
            pageid=pageid*total+1;  
        }  
        List<Emp> list=EmpDao.getRecords(pageid,total);  
        out.print("<h1>Page No: "+spageid+"</h1>");  
        out.print("<table border='1' cellpadding='4' width='60%'>");  
        out.print("<tr><th>Id</th><th>Name</th><th>Salary</th>");  
        for(Emp e:list){  
            out.print("<tr><td>"+e.getId()+"</td><td>"+e.getName()+"</td><td>"+e.getSalary()+"</td></tr>");  
        }  
        out.print("</table>");  
        %>  
        <a href="view.jsp?page=1">1</a>  
        <a href="view.jsp?page=2">2</a>  
        <a href="view.jsp?page=3">3</a>
    </body>
</html>

 

Emp.java

package Emp;
/**
 *
 * @author 91963
 */
public class Emp {
    private int id;  
    private String name;  
    private float salary;     

    public void setId(int aInt) {
        id = aInt;
    }

    public void setName(String string) {
        name = string;
    }

    public void setSalary(float aFloat) {
        salary = aFloat;
    }
    
    public int getId(){
        return id;
    }
    
    public String getName(){
        return name;
    }
    
    public float getSalary(){
        return salary;
    }
}   

 

EmpDao.java

package EmpDao;
import java.sql.*;  
import Emp.*;
import java.util.ArrayList;  
import java.util.List;   
/**
 *
 * @author 91963
 */
public class EmpDao {
    public static Connection getConnection(){  
        Connection con=null;  
        try{  
            Class.forName("com.mysql.jdbc.Driver");  
            con=DriverManager.getConnection("jdbc:mysql://localhost:3306/test","root","");  
        }catch(ClassNotFoundException | SQLException e){System.out.println(e);}  
        return con;  
    }  
    public static List<Emp> getRecords(int start,int total){  
        List<Emp> list=new ArrayList<>();  
        try
        {  
            try (Connection con = getConnection()) {
                PreparedStatement ps=con.prepareStatement("select * from emp limit "+(start-1)+","+total);
                ResultSet rs=ps.executeQuery();
                while(rs.next()){
                    Emp e=new Emp();
                    e.setId(rs.getInt(1));
                    e.setName(rs.getString(2));
                    e.setSalary(rs.getFloat(3));
                    list.add(e);
                }   }  
        }catch(Exception e){System.out.println(e);}  
        return list;  
    }  
}

 

输出

 

 

 

 

 

 

常见问题

  1. 什么是 JSP?
    JavaServer Pages 或 JSP 是一种基于 Java 的技术,用于创建动态网页。JSP 使用唯一的 JSP 标记帮助在 HTML 文件中插入 Java 代码。
     
  2. 什么是分页?
    分页用于将记录分成更方便的可读位,对用户和处理器都是如此,因为具有多条记录的单个页面可能需要时间来加载并且用户可能会很累。

关键要点

本博客涵盖了有关 JavaServer Pages 中分页的所有必要要点,深入讨论了其功能和分页应用的方法。以及它在 JavaServer Pages 中的实现。

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
自己收集的jsp分页代码。对于北大青鸟Y2的学员可能有用吧。自己也在做这个项目。这里有增、删、该、查加分页。有上一页、下一页、首页、尾页、第几页、还有带数字和点的分页。可以说是非常好的分页代码。想要的朋友自己处下载 <%@ page contentType="text/html; charset=GB2312" language="java" import="java.sql.*" errorPage="" %> <%@ page import="java.io.*" %> <%@ page import="java.util.*" %> <% java.sql.Connection sqlCon; //数据库连接对象 java.sql.Statement sqlStmt; //SQL语句对象 ResultSet sqlRst=null; //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; //设置一页显示的记录数 intPageSize = 2; //取得待显示页码 strPage = request.getParameter("page"); if(strPage==null){ //表明在QueryString中没有page这一个参数,此时显示第一页数据 intPage = 1; } else{ //将字符串转换成整型 intPage = java.lang.Integer.parseInt(strPage); if(intPage<1) intPage = 1; } %><% String DBUser="sa"; String DBPassword="88029712"; //String DBServer="127.0.0.1"zjprice; String DBUrl="jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=pubs"; //创建语句对象 //Class.forName("org.gjt.mm.mysql.Driver").newInstance(); Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver").newInstance(); sqlCon=java.sql.DriverManager.getConnection(DBUrl,DBUser,DBPassword); sqlStmt=sqlCon.createStatement(java.sql.ResultSet.TYPE_SCROLL_INSENSITIVE,java.sql.ResultSet.CONCUR_READ_ONLY); //执行SQL语句并获取结果集 String sql=null; String search=""; String ToPage=request.getParameter("ToPage"); if(request.getParameter("search")!=null &&!request.getParameter("search").equals("")) {search=new String(request.getParameter("search").trim().getBytes("8859_1")); } sql="select top 50 au_id,au_lname from authors "; /*sql="select*from ta,tb where id like'%"+search+"%'"; sql=sql+"or title like'%"+search+"%'"; sql=sql+"or time like'%"+search+"%'"; sql=sql+"or con like'%"+search+"%'"; sql=sql+"order by id";*/ sqlRst=sqlStmt.executeQuery(sql); //获取记录总数 sqlRst.last(); intRowCount = sqlRst.getRow(); //记算总页数 intPageCount = (intRowCount+intPageSize-1) / intPageSize; //调整待显示的页码 if(intPage>intPageCount) intPage = intPageCount; %> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> <title>test</title> </head> <body> <table border="1" cellspacing="0" cellpadding="0"> <tr> <th>标题id</th> <th>内容表</th> </tr> <% if(intPageCount>0) { //将记录指针定位到待显示页的第一条记录上 sqlRst.absolute((intPage-1) * intPageSize + 1); //显示数据 i = 0; while(i<intPageSize && !sqlRst.isAfterLast()){ %> <tr> <td> <%=sqlRst.getString(1)%> </td> <td> <%=sqlRst.getString(2)%> </td> </tr> <% sqlRst.next(); i++; } } %> <tr><td colspan="8">共有<font color=red><%= intRowCount %></font>条记录 当前<font color=red><%=intPage%>/<%=intPageCount%></font>页  <% if(intPageCount > 1){ %> <% if(intPage !=0){%> <a href="mysqlpage.jsp">首页</a> <%}if(intPage != 1){%><a href="mysqlpage.jsp?page=<%= intPage - 1 %>">上一页</a> <%}if(intPage<intPageCount){%><a href="mysqlpage.jsp?page=<%=intPage+1%>">下一页</a><%}%> <a href="mysqlpage.jsp?page=<%= intPageCount %>">尾页</a> <% } %>跳转到 <select name="page" onChange="javascript:this.form.submit();"> <% for(i=1;i<=intPageCount;i++){%> <option value="<%= i %>" <% if(intPage == i){%>selected<% } %>><%= i %></option> <% } %> </select>页 <%int m,n,p; %> <%if (intPage>1){ if(intPage-2>0){ m=intPage-2;} else { m=1;} if(intPage+2<intPageCount){ n=intPage+2;} else{ n=intPageCount; }%> 转到页码: [ <% for(p=m;p<=n;p++) { if (intPage==p){ %> <font color="black"><%=p %></font> <% } else{%> <a href=?page=<%=p %>><font color=red>[<%=p %>]</font></a> <% } }%>]<%} %> </td></tr> </table> </body> </html> <% //关闭结果集 sqlRst.close(); //关闭SQL语句对象 sqlStmt.close(); //关闭数据库 sqlCon.close(); %>
实现JSP与MySQL分页的步骤如下: 1.在JSP页面中定义一个分页函数,用于计算总记录数、总页数、当前页等信息。 ```jsp <% // 获取当前页码 int currentPage = request.getParameter("currentPage") == null ? 1 : Integer.parseInt(request.getParameter("currentPage")); // 定义每页显示的记录数 int pageSize = 10; // 定义总记录数 int totalCount = 0; // 定义总页数 int totalPage = 0; // 查询总记录数 String sqlCount = "select count(*) from table_name"; ResultSet rsCount = stmt.executeQuery(sqlCount); if (rsCount.next()) { totalCount = rsCount.getInt(1); } rsCount.close(); // 计算总页数 totalPage = totalCount % pageSize == 0 ? totalCount / pageSize : totalCount / pageSize + 1; // 判断当前页是否越界 if (currentPage < 1) { currentPage = 1; } else if (currentPage > totalPage) { currentPage = totalPage; } // 计算起始记录的索引值 int startIndex = (currentPage - 1) * pageSize; // 查询当前页的数据 String sqlData = "select * from table_name limit " + startIndex + "," + pageSize; ResultSet rsData = stmt.executeQuery(sqlData); while (rsData.next()) { // 显示数据 } rsData.close(); %> ``` 2.在JSP页面中显示分页导航条,用于用户选择不同的页码。 ```jsp <% // 显示分页导航条 for (int i = 1; i <= totalPage; i++) { if (i == currentPage) { out.println("<span>" + i + "</span>"); } else { out.println("<a href=\"?currentPage=" + i + "\">" + i + "</a>"); } } %> ``` 以上就是JSP与MySQL分页的基本实现方法。需要注意的是,这里的代码仅供参考,具体实现需要根据实际情况进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值