JSP网站开发基础总结《八》
JSP的学习总结到本篇已经八篇了,内容比较多,但都是实战,本篇最后为大家介绍一个小效果:百度分页。就是当我们遍历的数据对象较多时,这时我们就会看到了这个效果了,那他是如何实现的呢?下面我们就一起学习一下。
1、分页数据获取方法:
获得数据总数:
public int getSize() {
int num = 0;
Connection conn = null;
Statement st = null;
ResultSet rs = null;
conn = DBO.getConnection();
String sql = "select count(*) from students";
try {
st = conn.createStatement();
rs = st.executeQuery(sql);
rs.next();
num=rs.getInt(1);
} catch (SQLException e) {
e.printStackTrace();
}
return num;
}
计算一共分几页:
public int getPageCnt(int pageRec) {
int page = 0;
int size = this.getSize();
if(size>0){
page = (size-1)/pageRec+1;
}
return page;
}
获得在该页需要显示的数据:
public List<Student> getSome(int pageNo, int pageRec) {
List<Student> list = new ArrayList<Student>();
Connection conn = null;
Statement st = null;
ResultSet rs = null;
try {
conn=DBO.getConnection();
String sql="select * from students limit ";
int num = this.getSize()-pageNo*pageRec;
int a = this.getSize()-(pageNo-1)*pageRec;
if(num<0){
num=0;
}
sql+=(num)+","+ a;
st=conn.createStatement();
rs=st.executeQuery(sql);
while(rs.next()){
Student stu = new Student();
stu.setId(rs.getInt("id"));
stu.setName(rs.getString("username"));
stu.setSex(rs.getInt("sex"));
stu.setYear(rs.getInt("age"));
stu.setFrom(rs.getString("form"));
stu.setSchool(rs.getString("school"));
list.add(stu);
}
} catch (SQLException e) {
e.printStackTrace();
}finally{
DBO.close(rs, st, conn);
}
return list;
}
2、实现页面效果代码:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8" errorPage="error.html"%>
<%@page import="com.mysql.jsp.student.Student"%>
<%@page import="com.mysql.jsp.sever.StudentMaImp"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>"> <title>百度分页效果</title> <meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page"> </head> <body>
<%
int pageNo=1;
if(request.getParameter("p") !=null){
pageNo=Integer.parseInt(request.getParameter("p"));
}
int pageRec=5;//每页显示的数据条数
StudentMaImp smi = new StudentMaImp();
List<Student> list = smi.getSome(pageNo, pageRec);
int recCnt=smi.getSize();//得到总记录数
int pageCnt=smi.getPageCnt(pageRec);//得到总页数
%>
<center>
<h1>百度分页效果</h1>
<hr/>
<table border="1" width="80%">
<TR>
<td>编号</td><TD>ID</TD><td>姓名</td><td>性别</td><td>年龄</td><td>家乡</td><td>学校</td>
</TR>
<%
if(list.size()!=0 && pageNo>1 ){
for(int i=list.size()-1,j=1; i>=0; i--,j++){
Student student = list.get(i);
%>
<tr><td><%=j %></td><TD><%=student.getId() %></TD><td><%=student.getName() %></td><td><%if(student.getSex()==1){ %>男<%}else{ %>女<%} %></td><td><%=student.getYear() %></td><td><%=student.getFrom() %></td><td><%=student.getSchool() %></td></tr>
<%
}
}else{
for(int i=list.size()-1,j=1; i>=0&&list.size()!=0; i--,j++){
Student student = list.get(i);
%>
<tr><td><%=j %></td><TD><%=student.getId() %></TD><td><%=student.getName() %></td><td><%if(student.getSex()==1){ %>男<%}else{ %>女<%} %></td><td><%=student.getYear() %></td><td><%=student.getFrom() %></td><td><%=student.getSchool() %></td></tr>
<%
}
}
%>
<tr>
<td colspan="7" align="center">
<% if(pageNo!=1){ %>
<a href="All_BaiDu.jsp?p=1"><span>首页</span></a>
<%} %>
<% if(pageNo>1){ %>
<a href="All_BaiDu.jsp?p=<%=pageNo-1 %>"><span>上一页</span></a>
<%} %>
<%
for(int i=1;i<=pageCnt;i++){
if(i!=pageNo){
%>
<a href="All_BaiDu.jsp?p=<%=i %>"><span><%=i%></span></a>
<%}else{ %>
<span><%=i%></span></a>
<%}}%>
<% if(pageNo!=pageCnt){ %>
<a href="All_BaiDu.jsp?p=<%=pageNo+1 %>"><span>下一页</span></a>
<%} %>
<% if(pageNo!=pageCnt){ %>
<a href="All_BaiDu.jsp?p=<%=pageCnt %>"><span>尾页</span></a>
<%} %>
</td>
</tr>
</table>
</center>
</body>
</html>
效果图:

好了,到这里我们最简单的百度分页效果就实现了,具体的美化工作,就需要我们的css+div+javascript知识了,大家可以学习一下,对做网页帮助很大。
关于JSP的基础知识总结,到今天就为大家总结完毕,共计8篇博客,由于文字描述的局限,所以大家有什么疑问可以留言,我会一一为大家解答。
总结了这么多,最后给大家聊几句,学习JSP之前大家尽量先学习一下JAVASE的基础知识,对你理解JSP中的代码帮助很大,当然如果你对网站开发很感兴趣,可以学一下HTML之后再来学习JSP,这样对你了解里面的JSP语句帮助很大。不过有必要说一点的是,JSP开发现在远没有PHP开发那么受关注,PHP开发无须太多的基础,而JSP开发需要有一定的JAVA基础。大家如果没有JAVA基础,建议大家学习PHP,同样可以达到动态网站的开发的目的,而且PHP开发对于微信端开发很方便,所以大家如果对于JSP的学习感觉压力较大,建议大家学习PHP,不过任何一门技术刚刚接触时,都会存在很多的不懂,重要的是坚持,各种技术之间都是相通,当大家真正掌握一门技术后,再去接触别的技术,就会达到事半功倍的效果。
最后祝各位在程序猿这条路上能找到属于自己的蓝天。
JSP网站开发基础总结《八》的更多相关文章
- JSP网站开发基础总结《二》
有了上一篇的学习,我相信大家对于JSP一定有了一定的认识,从今天开始我们真正开启JSP模式,如果你有HTML的基础,那学起JSP来也就方便了很多了,首先JSP做为网站开发语言,它与HTML有很多相似的 ...
- JSP网站开发基础总结《一》
经过JAVASE的学习相信大家对JAVA已经不再陌生,那么JAVA都可以干什么呢?做算法.应用程序.网站开发都可以,从今天开始为大家奉上JAVAEE之JSP动态网站开发基础总结. 既然是动态网站开发, ...
- JSP网站开发基础总结《七》
按照计划本篇将为大家总结搜索功能的两种实现:确定搜索与模糊搜索.所谓精确搜索便是指,根据用户的输入的搜索内容,在数据库中寻找具有一一对应的关系的数据,一般都是用户在数据库中的主键值.而模糊搜索,是一种 ...
- JSP网站开发基础总结《十二》
前两篇已经简单为大家介绍了一下,有关Filter接口的知识,本篇就让我们以一个登录小功能,来具体实现一下过滤器的作用,便于大家掌握.具体为大家介绍一下如何使用Filter对访问进行过滤,及如何防止中文 ...
- JSP网站开发基础总结《四》
经过前几篇的摸爬滚打,下面我们就开始我们真正的数据库操作了,本篇重点在于如何在网站端编写数据库操作语句,内容不多,就是我们常见的增删改查. 0.数据库对象创建: 在JAVASE基础知识总结时,就为大家 ...
- JSP网站开发基础总结《十三》
继上一篇为大家补充过滤器类后,本篇为大家简单介绍一下如何实现验证码效果.验证码的作用是什么呢?1.防止恶意注册2.防止恶意提交3.防止盗取账户等等,总的来说验证码的存在就是为了,防止非人为的操作,不过 ...
- JSP网站开发基础总结《九》
本篇属于附加篇,在之前的总结中给大家提到过一个关于登录状态验证的效果,当时是通过Session对象完成的,今天我查了一下,JSP为我们封装了一个用于过滤用的过滤器类Filter,通过它我们就可以非常轻 ...
- JSP网站开发基础总结《六》
对于本篇需要总结的内容,量估计有点大,大家好好看哈,绝对全是干货,代码的已经运行测试,不存在问题,大家可以参考学习,下面开始本篇的内容. 1.添加数据到数据库: 如何用户在JSP页面的填写的信息输入到 ...
- JSP网站开发基础总结《九》(转)
本篇属于附加篇,在之前的总结中给大家提到过一个关于登录状态验证的效果,当时是通过Session对象完成的,今天我查了一下,JSP为我们封装了一个用于过滤用的过滤器类Filter,通过它我们就可以非常轻 ...
随机推荐
- No operation was found with the name {http://impl.service.xq.com/}sayHi
org.apache.cxf.common.i18n.UncheckedException: No operation was found with the name {http://impl.ser ...
- MySQL DELETE语句和TRUNCATE TABLE语句的区别
MySQL DELETE语句和TRUNCATE TABLE语句的区别 2010-10-08 16:05 佚名 互联网 字号:T | T 在MySQL数据库中,DELETE语句和TRUNCATE TAB ...
- bzoj 3110
题意:戳这里 思路:可以用cdq分治(很明显这种模型妹纸分治法很解决)..不过为了学习树套树特地写了一下.. 所谓的树套树也第一层(最外层)普通的维护的是一个node,而树套树维护的是一个数据结构(一 ...
- Android Studio 无法启动模拟器的一种可能是你装的是Ghost版的系统
我遇到的问题是,打开模拟器,进度条走到最后,突然出现了emulator error,然后模拟器就无法启动(不好意思当时没有截图).我是在Ghost版 win7系统下运行Android Studio 的 ...
- SQL入门经典(七) 之脚本和批处理
什么是脚本.我们前面学的CREATE TABLE <table name> ,USE <database name>这些都是脚本,为什么用脚本.脚本存储到文件中并且可以重复利用 ...
- SQL入门经典(四)之创建和修改数据表
本章主要讲如何使用脚本创建数据库:如何使用脚本创建表:如何删除对象和修改对象. CREATE 语句:CREATE <object type> <onject name> 创建数 ...
- 新浪微博UWP UI意见征求
各位园主,卑职最近在忙一些新浪微博UWP的事儿,其中有一些UI上的design和实现,拿出来见见公婆,请大家给个意见: 您是喜欢A还是B.麻烦直接回在评论区了,写A或B,愿意多写几句意见的更欢迎! 先 ...
- 【网站国际化必备】Asp.Net MVC 集成Paypal(贝宝)快速结账 支付接口 ,附源码demo
开篇先给大家讲段历史故事,博主是湖北襄阳人.襄阳物华天宝,人杰地灵,曾用名襄樊.在2800多年的历史文化中出现了一代名相诸葛亮(卧龙),三国名士庞统(凤雏),魏晋隐士司马徽(水镜先生),唐代大诗人孟浩 ...
- HTML5 history API实践
一.history API知识点总结 在HTML4中,我们已经可以使用window.history对象来控制历史记录的跳转,可以使用的方法包括: history.forward();//在历史记录中前 ...
- 在.net中使用aquiles访问Cassandra(一)
aquiles是.net下基于Thrift协议访问Cassandra的第三方类库,官方地址是: http://aquiles.codeplex.com/ 1.下载类库文件: http://aqui ...