关于根据字段排序的问题
最近在项目中遇见一个需要根据java类的字段排序的问题。为什么不直接在数据库里面进行排序呢?因为那是一张比较复杂的报表,显示的数据没什么规律,所以当时采用的是先查询出来然后再组装成一个java对象列表,现在领导居然要求根据列名排序!没办法,只得去试试。一般这种问题会有两种解决办法:
1.自己写个算法对列表的对象进行排序
2.实现对象的compareTo方法,然后用jdk自带的排序功能
个人比较倾向于第二种方法,但是起初想,要列的不同compareTo的实现也会不同,那么那个compareTo方法岂不是要动态生成?于是自己试着去看看cglib这个库,但这个库没什么文档,在网上的资料上看,主要也是用在动态代理上,能不能做到还难说,就算能,我还得花时间去看源码,于是放弃了。当然放弃之前经一同事提醒,可以采用一种迂回的方法,那就是定义一个排序字段,根据这个字段的值来判断对哪一列进行排序。如:
private String used0 = new String("0");private String used1 = new String("0");private String used2 = new String("0");private String used4 = new String("0");//排序字段,用于compareToprivate static String sortInput = "";@Overridepublic int compareTo(McRegData m) {if(sortInput.equals("used0")){return new BigDecimal(used0).compareTo(new BigDecimal(m.getUsed0()));}else if(sortInput.equals("used1")){return new BigDecimal(used1).compareTo(new BigDecimal(m.getUsed1()));}else if(sortInput.equals("used2")){return new BigDecimal(used2).compareTo(new BigDecimal(m.getUsed2()));}else if(sortInput.equals("used4")){return new BigDecimal(used4).compareTo(new BigDecimal(m.getUsed4()));}else if(sortInput.equals("usedE")){return new BigDecimal(usedE).compareTo(new BigDecimal(m.getUsedE()));}else if(sortInput.equals("usedU")){return new BigDecimal(usedU).compareTo(new BigDecimal(m.getUsedU()));}else if(sortInput.equals("used3")){return new BigDecimal(used3).compareTo(new BigDecimal(m.getUsed3()));}else if(sortInput.equals("usedR")){return new BigDecimal(usedR).compareTo(new BigDecimal(m.getUsedR()));}else if(sortInput.equals("total")){return new BigDecimal(this.getTotal()).compareTo(new BigDecimal(m.getTotal()));}return 0;if(map.get("sortInput")!=null&&map.get("sortType")!=null){String sortInput = map.get("sortInput").toString();String sortType = map.get("sortType").toString();//设置需要排序的字段McRegData.setSortInput(sortInput);Collections.sort(regList);if(sortType.equals("desc")){Collections.reverse(regList);}}public int compareTo(McRegData m) {try {BigDecimal old_field = new BigDecimal(MethodUtils.invokeMethod(this, "get"+StringUtils.capitalize(sortInput)).toString());BigDecimal new_field = new BigDecimal(MethodUtils.invokeMethod(m, "get"+StringUtils.capitalize(sortInput)).toString());return old_field.compareTo(new_field);} catch (Exception e) {//非数字列会出现异常e.printStackTrace();}return 0;}