最近刚开始帮同学做个创新的项目,用ssh做框架,学了这么久还没有用ssh做过什么项目,也忘了不少了,所有就有了这篇龊文,简单的回顾一下ssh框架的搭建。同时也学习一下hibernate的简单分页技术。
下面是显示效果
下面是ssh框架的结构,(本人用的是eclipse)
对于一些配置文件的内容这里就不在叙述了,关于分页有一工具类代码如下
public class PageControl
{
private Integer curpage; //当前页
private int prepage; //上一页
private int nextpage; //下一页
private int totalpage; //总页数
private int start; //当前页起始记录
private int end; //当前页结束记录
private int totalnum; //总记录数
private int int_num = 4;//每页显示行数
private int temp_curpage;
private int temp_totalpage;
private int temp_start;
private int temp_end;
private int temp_totalnum;
public void init(int curpage,int totalnum)
{
// 总记录数
temp_totalnum = totalnum;
// 总页数
temp_totalpage = (int)Math.ceil((double)totalnum/(double)int_num);
// 当前页
if (curpage > 1)
{
if (curpage > temp_totalpage)
{
temp_curpage = temp_totalpage;
}
else
{
temp_curpage = curpage;
}
}
else
{
temp_curpage = 1;
}
// 当页起始记录
temp_start = (temp_curpage-1) * int_num + 1;
// 当页结束记录
temp_end = temp_curpage * int_num;
if (temp_end > temp_totalnum)
{
temp_end = temp_totalnum;
}
setCurpage();
setPrepage();
setNextpage();
setTotalpage();
setStart();
setEnd();
setTotalnum();
}
public void setCurpage()
{
this.curpage = temp_curpage;
}
public int getCurpage()
{
return this.curpage;
}
public void setPrepage()
{
if (temp_curpage - 1 < 1)
{
this.prepage = 1;
}
else
{
this.prepage = temp_curpage - 1;
}
}
public int getPrepage()
{
return this.prepage;
}
public void setNextpage()
{
if (temp_curpage + 1 > temp_totalpage)
{
this.nextpage = temp_totalpage;
}
else
{
this.nextpage = temp_curpage + 1;
}
}
public int getNextpage()
{
return this.nextpage;
}
public void setTotalpage()
{
this.totalpage = temp_totalpage;
}
public int getTotalpage()
{
return this.totalpage;
}
public void setStart()
{
this.start = temp_start;
}
public int getStart()
{
return this.start;
}
public void setEnd()
{
this.end = temp_end;
}
public int getEnd()
{
return this.end;
}
public void setTotalnum()
{
this.totalnum = temp_totalnum;
}
public int getTotalnum()
{
return this.totalnum;
}
/**
* @return 返回 int_num。
*/
public int getInt_num()
{
return int_num;
}
/**
* @param int_num 要设置的 int_num。
*/
public void setInt_num(int int_num)
{
this.int_num = int_num;
}
}
其次就是在action中定义pageControl对象,配置对象的属性就可以了。
action中核心代码如下:
private TestIservice tser;
private List<Test> test;
private PageControl page; //pageControl对象
private int curpage; //当前第几页
public String query()throws Exception{
if(page == null) {//判断,第一次为空时创建pageConrol对象
page = new PageControl();
}
page.setInt_num(5);//设置每页显示条数
page.init(curpage, tser.queryInfoNum());//初始化pageControl对象,一个参数为当前页数,另一个为查询的总条数
test = tser.queryAllInfo(page);
return "return_query";
}
在Dao中显示的也有一部分需要注意,该层中的查询语句如下
String hql = " from Test ";
System.out.println(hql);
Query query = session.createQuery(hql);
query.setFirstResult(start);
query.setMaxResults(num);
List<Test> list = query.list();
return list;
下面是代码例子下载地址:
http://download.csdn.net/detail/z1093776496/6239503