`
toyota2006
  • 浏览: 551594 次
  • 性别: Icon_minigender_1
  • 来自: 石家庄
社区版块
存档分类
最新评论

ET Limit方式的分页查询

阅读更多
1.Limit
   默认的情况下eXtremeTable取得所有的结果集然后处理Beans集合,这样的好处是 你可以随意进行排序、过滤和分页操作。
你只需要组装Beans集合并让eXtremeTable知道如何 然而在查询结果较大,可以考虑使用数据库端分页的方案。此时,eXtremeTable
会使用Limit对象向Action/Controller传递PageNo,PageSize,OrderBy等分页信息。而服务端将向EC返回总记录数和当前页的内容。

2.创建Limit
   
    首先你需要通过LimitFactory得到一个Limit实例:

   
     
Context context = new HttpServletRequestContext(request);
      LimitFactory limitFactory = new TableLimitFactory(context);
      Limit limit = new TableLimit(limitFactory); 
  
   Limit对象定义了limit结果集的所有方法。
  TableLimitFactory具有另外一个构造函数,如果JSP页面使用了两个(以上)eXtremeTable的话你可以利用tableId分别传输totalRows,如果默认tableId将为所有ec,。

   

Context context = new HttpServletRequestContext(request);
    LimitFactory limitFactory = new TableLimitFactory(context, tableId);
    Limit limit = new TableLimit(limitFactory);   
   设置行属性:

        limit.setRowAttributes(totalRows, DEFAULT_ROWS_DISPLAYED);

3. 前台jsp页面中ec标莶写法: 
 
   
   

<ec:table
        items="userlist"
        var="u"
        action="/pageAction.do"       
        title="后台用户管理——管理用户"
        retrieveRowsCallback="limit" 
        width="80%"
        rowsDisplayed="3"
        form=""
        >   
        <ec:row>
            ...
            ...           
        </ec:row>
    </ec:table>
   
    使用callback需要做的唯一事情是传输集合到request,同时传输totalRows属性。 totalRows表示总行数,
 

      
request.setAttribute("userlist", userlist);
       request.setAttribute("totalRows", new Integer(总记录数));


   

4.实例:
本实例是ec结合Struts和Hibernate进行分页.
   
     PageAction中的部分代码:
     

public ActionForward execute(ActionMapping mapping, ActionForm form,
  HttpServletRequest request, HttpServletResponse response)
        throws Exception {
     UserDAO userDAO = (UserDAO) getBean("userDAO"); 
     Limit limit = ExtremeTablePage.getLimit(request,defaultPageSize);
     PageBean page = new PageBean();
     page.setPageSize(limit.getCurrentRowsDisplayed()); //ec通过limit对象传递pageSize给PageBean
     page.setPage(limit.getPage());//ec通过limit对象传递pageNo给PageBean
     List list = userDAO.findAllUser(page);
     request.setAttribute("userlist", list);
     request.setAttribute("totalRows", new Integer(page.getCount()));
    
     return mapping.findForward("userlist");
  
 } 
   
     Limit对象的实例化在ExtremeTablePage中
 

     static public Limit getLimit(HttpServletRequest request,int defaultPageSize) {
        Context context = new HttpServletRequestContext(request);
        LimitFactory limitFactory = new TableLimitFactory(context);
        TableLimit limit = new TableLimit(limitFactory);
        limit.setRowAttributes(Integer.MAX_VALUE, defaultPageSize);
        return limit;
      } 
    
     
PageBean类部分代码:
    
     

public class PageBean {
      private int count = 0; // 记录总数
      private int pageSize = 10; // 每页显示记录数
          private int pageCount = 0; // 总页数
          private int page = 1; // 当前页数
          .
          .
          .
          public int getCount() {
             return count;
         }
       public void setCount(int count) {
          if (pageSize != 0) {
             pageCount = count / pageSize;
          if (count % pageSize != 0) {
             pageCount++;
           }
       }
       this.count = count;
      }
 
      public int getPage() {
        return page;
      }
     public void setPage(int page) {
       this.page = page;
     }
     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;
     }
  .
  .
  .
 }
dao层使用PageBean对象进行查询。
分享到:
评论
1 楼 zhang20084 2007-09-16  
不能排序怎么办办呢

相关推荐

    根据Ecside ET 源码改变WEB JSP 分页标签

    在IT行业中,网页分页是常见的数据展示方式,特别是在大数据量的列表中,它能帮助用户更有效地浏览和管理信息。ECSide是一款强大的开源Java Web开发工具,它提供了丰富的功能,包括对JSP页面的分页处理。本文将深入...

    ET200S和ET200M有什么差别

    ### ET200S与ET200M的主要区别 #### 一、概述 ET200S和ET200M是西门子公司推出的分布式I/O系统中的两种型号,它们均属于SIMATIC ET 200系列。该系列旨在为工业自动化提供灵活且高效的解决方案。ET200S与ET200M虽然...

    西门子SIMATIC ET200pro和ET 200eco选型指导样本.pdf

    西门子SIMATIC ET200pro和ET 200eco选型指导样本pdf,西门子SIMATIC ET200pro和ET 200eco选型指导样本 SIMATIC ET200是多功能、模块化、灵活的分布式I/O,可以安装在控制柜里,机器设备上或者具有爆炸危险的场所。...

    ET2006/ET2008/2016/2018四合一免狗版

    ET2006/ET2008/2016/2018四合一免狗版,绝对的四合一,如假包换。压缩包里分别et_V5.et_V6.et_V7.et_V8/四个打版软件,其中2018版的带滚轮放大缩小,无需按住shift键盘,看到的版师您有福了。打版软件里不存在任何像...

    et199_dongle_et199_

    "et199_dongle_et199_" 是一个与ET199开发板相关的压缩包文件,其中包含了各种资源和文档,用于帮助开发者进行软件开发和硬件调试。ET199通常指的是一个嵌入式设备或者模块,可能是用于物联网(IoT)应用、数据采集、...

    ET199改客户号和ATR.rar_et199客户号_et199改客户号_改号_模拟ET199_锁

    ET199是一种智能电子锁系统,主要用于门禁控制或安全访问管理。在这个主题中,我们主要探讨如何修改ET199锁的客户号和ATR(Answer To Reset)值,以及如何进行模拟操作。 首先,我们要理解"客户号"在ET199系统中的...

    ET199动态通讯密码获取工具_获取_et199_ET199获取密码工具_

    ET199设备可能是一种硬件安全模块或者智能卡,它生成一次性的动态密码,增加了数据传输和系统访问的安全性。 首先,我们来理解一下动态密码的概念。动态密码是一种安全认证方式,与传统的静态密码不同,它每次登录...

    TIA博途中使用ET200SP PTP模块的MODBUS RTU通信方式具体方法.pdf

    本文将详细讲解如何在TIA博途中利用ET200SP PTP(Point-to-Point)模块实现MODBUS RTU通信。TIA博途是西门子的全集成自动化软件平台,它提供了集成工程、编程、诊断和维护等功能。 **1. MODBUS RTU通信概述** ...

    ET200SP-GSD文件-GSDML-V2.43-Siemens-ET200SP-20240209.zip

    ET200SP是西门子(Siemens)推出的一款分布式I/O系统,它是SIMATIC自动化家族中的一个重要组成部分。GSD文件(Generic Station Description File),全称通用站描述文件,是一种标准化格式,用于描述自动化设备的...

    ET200SP接线图.pdf

    根据提供的文件内容,我们可以了解到西门子ET200SP的接线相关信息。在详细解读这部分内容时,需要注意识别出正确的设备和接线方式,尽管可能存在的OCR技术误差需要修正。以下详细知识点: 1. 接线图与接线方式: ...

    S71500_ET200MP_ET200SP_ET200AL_ET200PRO_Profinet通信功能使用手册.pdf

    这份手册是针对西门子S7-1500、ET200MP、ET200SP、ET200AL、ET200pro等系列产品的Profinet通信功能的使用说明。这些设备都是西门子公司推出的一系列工业自动化产品,广泛应用于自动化控制系统中。 Profinet是一种...

    ET超排免费版

    "ET超排免费版"是一款专为服装行业设计的排料软件,它的主要功能是帮助用户高效、节省地安排裁剪方案。与传统的博克软件相比,ET超排免费版在处理ET格式的服装设计文件时,具有更高的效率和节省材料的优势。 软件的...

    ET2017万能DXF原版带ET睿排.zip

    《ET2017万能DXF原版带ET睿排——高效CAD设计新体验》 ET2017是一款专业级别的计算机辅助设计(CAD)软件,尤其在电子图板领域有着广泛的应用。该版本“万能DXF原版”意味着它支持与多种CAD软件进行数据交换,特别...

    EtherCAT ET1100 datasheet

    这部分内容对于硬件设计工程师来说至关重要,因为它们需要了解芯片的物理连接方式和电气特性以确保与其它硬件设备的兼容性。在硬件描述中,通常会包含引脚图和引脚定义,以帮助设计人员进行正确的布线和连接。 接着...

    ET2008万能版工业免狗(可打开所有ET文件/ET旗帜版/带DXF功能) 2

    ET2008万能版工业免狗(可打开所有ET文件/ET旗帜版/带DXF功能) 共两个文件 ET2008安装.part1.rar ET2008安装.part2.rar QQ;5232626234

    ET200S.ZIP_ET200S_ET200S gsd_GSD_et200s gsd_profibus

    GSD files for all ET200S Profibus DP Slaves from SIEMENS

    ET2008万能版工业免狗(可打开所有ET文件/ET旗帜版/带DXF功能)

    ET2008万能版工业免狗(可打开所有ET文件/ET旗帜版/带DXF功能) 共有两个文件 ET2008安装.part1.rar ET2008安装.part2.rar QQ;523626234 www.lxlzg.com

    ET破解万能版

    ET破解

    SIMATIC S7-1500、ET 200MP、ET 200SP、ET 200AL、ET 200pro 通信[手册].pdf

    西门子SIMATIC S7-1500系列PLC与ET200系列模块化远程I/O设备,包括ET200MP、ET200SP、ET200AL和ET200pro,是工业自动化领域中用于控制和监控制造过程的先进产品。本手册详细介绍了这些设备的通信功能和特性,包括但...

Global site tag (gtag.js) - Google Analytics