java 分页方法

dto   ,存放分页信息 

 

package com.cp3.jm.common.bc;

import java.io.Serializable;


public class JmCommonDto  implements Serializable{
	private static final long serialVersionUID = -1L;
	private String page;
	private String pagesize;
	private String sortname;
	private String sortorder;
	public String getPage() {
		return page;
	}
	public void setPage(String page) {
		this.page = page;
	}
	public String getPagesize() {
		return pagesize;
	}
	public void setPagesize(String pagesize) {
		this.pagesize = pagesize;
	}
	public String getSortname() {
		return sortname;
	}
	public void setSortname(String sortname) {
		this.sortname = sortname;
	}
	public String getSortorder() {
		return sortorder;
	}
	public void setSortorder(String sortorder) {
		this.sortorder = sortorder;
	}
}


分页方法

 

/**
	 * 排序分页方法
	 * @param sql
	 * @param dto
	 * @return
	 */
	public Map getSortPagedSQL(String sql,JmCommonDto dto ){
		if(dto == null){
			throw new BusinessException("传入分页对象jmCommonDto不能为空");
		}
		if(dto.getPagesize() == null || Integer.parseInt(dto.getPagesize()) <0){
			throw new BusinessException("每页显示数目为空或小于0");
		}
		if(dto.getPage() == null  || (Integer.parseInt(dto.getPage())) <0){
			throw new BusinessException("请求当前页数为空或小于0");
		}
		int startRow = (Integer.parseInt(dto.getPage())-1)*Integer.parseInt(dto.getPagesize())+1 ;
		int endRow = (Integer.parseInt(dto.getPage()))*Integer.parseInt(dto.getPagesize()) ;
		StringBuffer sb = new StringBuffer();
		sb.append(" select  count(1) count from ( ")
		.append(sql).append(" ) t");
		List listcount = ip.executeSQLQuery(sb.toString());
		map.put("Total",((DynaBean)listcount.get(0)).get("count"));
		sb  = new StringBuffer();
		sb.append(" select t.* from ( ").append(" select ");
		if(dto.getSortname() != null){
			sb.append(" row_number() over(order by ").append( dto.getSortname());
			if(dto.getSortorder() != null){
				sb.append(" ").append(dto.getSortorder());
			}
			sb.append(" )  ");
		}else{
			sb.append(" rownum ");
		}
		
		sb.append(" id, t1.* from ( ").append(sql).append(" ) t1").append(" ) t");
		sb.append(" where  id between ").append(startRow ).append(" and ").append(endRow);
		List list = ip.executeSQLQuery(sb.toString());
		map.put("Rows", list);
		return map;
	}


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值