/** * 辅助拼接HQL声明工具 * @author G-Xia * */public class QueryHelper { private String fromClause; // From子句 private String whereClause = ""; // Where子句 private String orderByClause = ""; // OrderBy子句 private List
" ASC" : " DESC"); } return this; } /** * 假设第一个參数的值为true,就拼接OrderBy子句 * * @param append * @param propertyName * @param asc */ public QueryHelper addOrderByProperty(boolean append, String propertyName, boolean asc) { if (append) { addOrderByProperty(propertyName, asc); } return this; } /** * 获取查询数据列表的HQL语句 * * @return */ public String getQueryListHql() { return fromClause + whereClause + orderByClause; } /** * 获取查询总记录数的HQL语句(没有OrderBy子句) * * @return */ public String getQueryCountHql() { return "SELECT COUNT(*) " + fromClause + whereClause; } /** * 获取參数列表 * * @return */ public List<Object> getParameters() { return parameters; } /** * 准备PageBean对象到Struts2的栈顶 * @param service * @param pageNum */ public void preparePageBean(DaoSupport<?> service, int pageNum){ PageBean pageBean = service.getPageBean(pageNum, this); ActionContext.getContext().getValueStack().push(pageBean); } }
PageBean:分页用的页面信息
public class PageBean { // 传递的參数或配置的值 private int currentPage; // 当前页 private int pageSize; // 每页显示的记录数 // 查询数据库 private int recordCount; // 总记录数 private List recordList; // 本页的数据列表 // 计算出来的 private int pageCount; // 总页数 private int beginPageIndex; // 页面列表的開始索引 private int endPageIndex; // 页面列表的结束索引 /** * 仅仅接受前4个必要的属性的值,会自己主动的计算出后3个属性的值 * * @param currentPage * @param pageSize * @param recordCount * @param recordList */ public PageBean(int currentPage, int pageSize, int recordCount, List recordList) { this.currentPage = currentPage; this.pageSize = pageSize; this.recordCount = recordCount; this.recordList = recordList; // 计算pageCount pageCount = (recordCount + pageSize - 1) / pageSize; // 计算begPageIndex和endPageIndex // a, 总页数不超过10页,就所有显示 if (pageCount <= 10) { beginPageIndex = 1; endPageIndex = pageCount; } // b, 总页数超过了10页,就显示当前页附近的共10个页码(前4个 + 当前页 + 后5个) else { // 显示当前页附近的共10个页码(前4个 + 当前页 + 后5个) beginPageIndex = currentPage - 4; // 7 - 4 = 3 endPageIndex = currentPage + 5; // 7 + 5 = 12 // 当前面不足4个页码时,就显示前10页 if (beginPageIndex < 1) { beginPageIndex = 1; endPageIndex = 10; } // 当后面不足5个页码时。就显示后10页 else if (endPageIndex > pageCount) { endPageIndex = pageCount; beginPageIndex = pageCount - 10 + 1; // 注意在显示的时候是包括两个边界的 } } } public int getCurrentPage() { return currentPage; } public void setCurrentPage(int currentPage) { this.currentPage = currentPage; } public int getPageCount() { return pageCount; } public void setPageCount(int pageCount) { this.pageCount = pageCount; } public int getPageSize() { return pageSize; } public void setPageSize(int pageSize) { this.pageSize = pageSize; } public int getRecordCount() { return recordCount; } public void setRecordCount(int recordCount) { this.recordCount = recordCount; } public List getRecordList() { return recordList; } public void setRecordList(List recordList) { this.recordList = recordList; } public int getBeginPageIndex() { return beginPageIndex; } public void setBeginPageIndex(int beginPageIndex) { this.beginPageIndex = beginPageIndex; } public int getEndPageIndex() { return endPageIndex; } public void setEndPageIndex(int endPageIndex) { this.endPageIndex = endPageIndex; }}
/** * 公共的查询分页信息的方法(终于版) * * @param pageNum * @param queryHelper * 查询语句 + 參数列表 * @return */ public PageBean getPageBean(int pageNum, QueryHelper queryHelper) { System.out.println("------------> DaoSupportImpl.getPageBean( int pageNum, QueryHelper queryHelper )"); // 获取pageSize等信息 int pageSize = Configuration.getPageSize(); Listparameters = queryHelper.getParameters(); // 查询一页的数据列表 Query query = getSession().createQuery(queryHelper.getQueryListHql()); if (parameters != null && parameters.size() > 0) { // 设置參数 for (int i = 0; i < parameters.size(); i++) { query.setParameter(i, parameters.get(i)); } } query.setFirstResult((pageNum - 1) * pageSize); query.setMaxResults(pageSize); List list = query.list(); // 查询 // 查询总记录数 query = getSession().createQuery(queryHelper.getQueryCountHql()); // 注意空格。 if (parameters != null && parameters.size() > 0) { // 设置參数 for (int i = 0; i < parameters.size(); i++) { query.setParameter(i, parameters.get(i)); } } Long count = (Long) query.uniqueResult(); // 查询 return new PageBean(pageNum, pageSize, count.intValue(), list); }
// 准备分页的数据 -- 使用QueryHelper new QueryHelper(Topic.class, "t")// .addWhereCondition("t.forum=?", forum)// .addWhereCondition((viewType == 1), "t.type=?", Topic.TYPE_BEST) // 1 表示仅仅看精华帖 .addOrderByProperty((orderBy == 1), "t.lastUpdateTime", asc) // 1 表示仅仅按最后更新时间排序 .addOrderByProperty((orderBy == 2), "t.postTime", asc) // 表示仅仅按主题发表时间排序 .addOrderByProperty((orderBy == 3), "t.replyCount", asc) // 表示仅仅按回复数量排序 .addOrderByProperty((orderBy == 0), "(CASE t.type WHEN 2 THEN 2 ELSE 0 END)", false)// .addOrderByProperty((orderBy == 0), "t.lastUpdateTime", false) // 0 表示默认排序(全部置顶帖在前面。并按最后更新时间降序排列) .preparePageBean(topicService, pageNum);
JSP中页面信息
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%><%@ taglib prefix="s" uri="/struts-tags" %><%-- 分页信息 --%>
id=${id}&pageNum=" + pageNum; // alert("请实现gotoPage()方法!"); // 方式二: $("#pageForm").append("<input type='hidden' name='pageNum' value='" + pageNum + "'>"); // 加入pageNum表单字段 $("#pageForm").submit(); // 提交表单 } </script>
版权声明:本文博客原创文章,博客,未经同意,不得转载。