jmesa - column sorting

<!-- /* Font Definitions */ @font-face {font-family:宋体; panose-1:2 1 6 0 3 1 1 1 1 1; mso-font-alt:SimSun; mso-font-charset:134; mso-generic-font-family:auto; mso-font-pitch:variable; mso-font-signature:3 135135232 16 0 262145 0;} @font-face {font-family:"/@宋体"; panose-1:2 1 6 0 3 1 1 1 1 1; mso-font-charset:134; mso-generic-font-family:auto; mso-font-pitch:variable; mso-font-signature:3 135135232 16 0 262145 0;} /* Style Definitions */ p.MsoNormal, li.MsoNormal, div.MsoNormal {mso-style-parent:""; margin:0cm; margin-bottom:.0001pt; text-align:justify; text-justify:inter-ideograph; mso-pagination:none; font-size:10.5pt; mso-bidi-font-size:12.0pt; font-family:"Times New Roman"; mso-fareast-font-family:宋体; mso-font-kerning:1.0pt;} /* Page Definitions */ @page {mso-page-border-surround-header:no; mso-page-border-surround-footer:no;} @page Section1 {size:612.0pt 792.0pt; margin:72.0pt 90.0pt 72.0pt 90.0pt; mso-header-margin:36.0pt; mso-footer-margin:36.0pt; mso-paper-source:0;} div.Section1 {page:Section1;} -->

Jmesa column sorting

 

rocars 中定义了

package customs.rocars.hibernate;

 

public class PagedCriteria {

 

    private PageFilter pageFilter = new PageFilter( );

   

    private PageSort pageSort = new PageSort( );

 

    public PageFilter getPageFilter() {

       return pageFilter ;

    }

 

    public void setPageFilter(PageFilter pageFilter) {

       this . pageFilter = pageFilter;

    }

 

    public PageSort getPageSort() {

       return pageSort ;

    }

 

    public void setPageSort(PageSort pageSort) {

       this . pageSort = pageSort;

    }

}

//

package customs.rocars.hibernate;

 

import java.util.ArrayList;

import java.util.List;

 

import customs.rocars.dto.SortDTO;

 

public class PageSort {

 

       List<SortDTO> sorts = new ArrayList<SortDTO>();

 

    public void addSort(String property, String order) {

        sorts.add(new SortDTO(property, order));

    }

 

       public List<SortDTO> getSorts() {

              return sorts;

       }

 

       public void setSorts(List<SortDTO> sorts) {

              this.sorts = sorts;

       }

 

}

/

可以在 controller 中调用一下 code ,从而获得 jmesa 为我们封装好的 sorting attribute

pagedCriteria.setPageSort(TableFacadeUtils.getCommonSort (tableFacade.getLimit()));

 

为了能让在 print 的时候也能用到 sorting attribute ,添加了以下一句 code

//remove comment here, you can apply column sorting (1st steps)

eqVehCrossHistoryDTO.setPrintPageSort(pagedCriteria.getPageSort());

 

最后,在 dao 中调用以下代码构造 order by

/*//remove comment here, you can apply column sorting (2st steps)

              //counstruct order string

              String orderString = CommonSortUtil.getOrderString(dto .getPrintPageSort(), new EqVehCrossHistorySort());

              if(!StringUtil.isEmptyString(orderString)){

                  hqlBuffer.append(orderString);

              }else{

                  //default order by string

                  hqlBuffer.append(" ORDER BY VCFL.VEH_REGT_MK");

              }

              */

当然,这种做法是基于使用 SQL 进行查询的时候的做法。

至于用 Hql Criteria 的做法也类似。

 

同时,以上的做法是适用于有多个 order by case ,因为 jmesa 缺省的 column sorting 是可以同时有多个 column 一起排序的。

 

如果先每次只用一个 column 排序,那就得修改 jmesa 的源码了,不难,加多一句就可以了,

 

 

 

 

 

 

addSortToLimit : function (id, position, property, order) {

             

           removeAllSortsFromLimit(id); // 加上这一句就可以了

          

/*First remove the sort if it is set on the limit,

               and then set the page back to the first one.*/

            this .removeSortFromLimit(id, property);

            this .setPageToLimit(id, '1' );

 

            var limit = this .getTableFacade(id).limit;

            var sort = new classes.Sort(position, property, order);

            limit.addSort(sort);

        },

还有只有一个 column 的情况,构造 order by 的时候就相对简单了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值