ecside 数据库分页

本文介绍了一种基于ECSIDE框架的数据库分页实现方法,通过自定义的Limit和Sort类对SQL语句进行分页处理,并可根据是否全量导出决定是否应用分页限制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 ecside 数据库分页后台代码如下:
public int rowStart = 0;//每页的起始位置

public int rowEnd = 20;// 每页显示多少页
/**
  * 判断是否要加上记录限制,全部导出,则不需要加limit
  *
  * @param sql
  * @return
  */
 private String limitRange(String sql) {
  HttpServletRequest request = ServletActionContext.getRequest();
  Limit limit = RequestUtils.getLimit(request);
  // WebContext context = new HttpServletRequestContext(request);
  String exportPage = request
    .getParameter(TableConstants.EXPORT_PAGE_FLAG);
  Boolean exportAll = "true".equalsIgnoreCase(exportPage);
  if (limit.isExported() && !exportAll) {// 是全部导出,,如pdf全部导出
  } else {
   sql = sql + " limit " + rowStart + "," + rowEnd;
  }
  return sql;
 }

public void sqlpage(String strsql) throws Exception {
  ResultSet rsPage = null;
  HttpServletRequest request = ServletActionContext.getRequest();
  Limit limit = RequestUtils.getLimit(request);
  Sort sort = limit.getSort();
  Map sortValueMap = sort.getSortValueMap();
  int totalRows = RequestUtils.getTotalRowsFromRequest(request);
  if (totalRows < 0) {

   rsPage = this.getReportQueryManger().getReportRecords(strsql);
   while (rsPage != null && rsPage.next()) {
    totalRows = rsPage.getInt("totalnum");
   }
  }
  limit.setRowAttributes(totalRows, DEFAULT_PAGE_SIZE);
  // offset表示数据编号的起始号.

  int offset = 0;

  rowStart = limit.getRowStart() + offset;
  rowEnd = limit.getRowEnd() - limit.getRowStart();

  
 }
前台设置为retrieveRowsCallback="limit"

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值