分页实现:
实现数据的分页显示,需要以下几个关键步骤:
①确定每页显示的总页数
②计算显示的总页数
③编写SQL语句
实现效果如图所示:
当点击下一页时,地址栏地址为?pageIndex=2
1、创建util包,Page类,定义相关属性并进行封装:
package cn.news.util; import java.util.List; import cn.news.entity.NewsDetail; public class Page { //当前页
private int pageIndex; //页面记录数
private int pageSize; //本业显示真实数据
private List<NewsDetail> list; //总页数
private int totalPages; //总记录数
private int totalRecords; public int getPageIndex() {
return pageIndex;
} public void setPageIndex(int pageIndex) {
this.pageIndex = pageIndex;
} public int getPageSize() {
return pageSize;
} public void setPageSize(int pageSize) {
this.pageSize = pageSize;
} public List<NewsDetail> getList() {
return list;
} public void setList(List<NewsDetail> list) {
this.list = list;
} public int getTotalPages() {
return totalPages;
} public void setTotalPages(int totalPages) {
this.totalPages = totalPages;
} public int getTotalRecords() {
return totalRecords;
} public void setTotalRecords(int totalRecords) {
this.totalRecords = totalRecords;
}
}
2、在Dao实现类NewsDetailDaoImpl定义获取新闻当前页的数据的方法getonePage,并植入两个参数pageIndex, pageSize
@Override
public List<NewsDetail> getonePage(int pageIndex, int pageSize)
throws Exception {
List<NewsDetail> list=new ArrayList<NewsDetail>();
String sql="select top "+pageSize+" * from newsDetails where newsId not in(select top "+(pageIndex-1)*pageSize+" newsId from newsDetails)";
ResultSet rs=executeQuery(sql); if(rs!=null)
{
while(rs.next())
{
NewsDetail news=new NewsDetail(); news.setNewsId(rs.getInt("newsId"));
news.setNewsTitle(rs.getString("newsTitle"));
news.setNewsContent(rs.getString("newsContent"));
news.setNewsCreateDate(rs.getDate("newsCreateDate"));
news.setNewsAuthor(rs.getString("newsAuthor"));
news.setNewsCategoryId(rs.getInt("newsCategoryId")); list.add(news);
}
}
return list; }
3、在NewsServlet类中把数据传递给Jsp页面
package cn.news.servlet; import java.io.IOException; import java.util.List; import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import cn.news.entity.NewsDetail;
import cn.news.impl.NewsDetailDaoImpl;
import cn.news.util.Page; public class NewsServlet extends HttpServlet { /** */
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException { doPost(request,response); } /** */
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException { //实例化dao
NewsDetailDaoImpl dao=new NewsDetailDaoImpl(); try {
Page page=new Page();
//默认3条数据
int pageSize=3;
page.setPageSize(pageSize);
//当前页
int myindex=1;
String pageIndex=request.getParameter("pageIndex");
if(pageIndex!=null&&(!pageIndex.equals("")))
{
myindex=Integer.parseInt(pageIndex);
}else {
myindex=1;
}
//当前页赋值
page.setPageIndex(myindex); int mytotalPages=0;
int totalPages=dao.getAllCount();
if(totalPages%pageSize==0)
{
mytotalPages=totalPages/pageSize;
}
else
{
mytotalPages=totalPages/pageSize+1;
}
page.setTotalPages(mytotalPages); //泛型数据
List<NewsDetail> list= dao.getonePage(page.getPageIndex(), pageSize);
page.setList(list); request.setAttribute("list", page);
request.getRequestDispatcher("/index.jsp").forward(request, response); //List<NewsDetail> list=dao.getAllNews(); } catch (Exception e) {
e.printStackTrace();
} } }
4、在index.jsp页面得到泛型集合,并获取当前页数和下一页
<%
Page page2=(Page)request.getAttribute("list");
for(NewsDetail item:page2.getList())
{ %>
<li><a href='newspages/news_read.jsp'><%=item.getNewsTitle() %></a><span><%=item.getNewsCreateDate() %></span></li> <%
} %> <p align="right"> 当前页数:[<%=page2.getPageIndex() %>/<%=page2.getTotalPages() %>] <a href="<%=path %>/servlet/NewsServlet?pageIndex=<%=page2.getPageIndex()+1%>">下一页</a> <a href="#">末页</a> </p>
</ul>