`

关于根据字段排序的问题

 
阅读更多
最近在项目中遇见一个需要根据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");
//排序字段,用于compareTo
private static String sortInput = "";

即上面的sortInput字段,如果sortInput="used0",那么就根据used0进行排序。具体实现如下:
1.实现Comparable接口,最后加上类型,如Comparable<McRegData>
2.实现compareTo方法:
@Override
	public 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;

因为只比较数字字段,所以把它转型成BigDecimal,上面只是对临时组装的对象类进行了相应的处理,最后再对整个列表数据进行排序:
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);
				}
			}

其中map.get("sortInput")等是外部传进来的排序参数。上面的代码中,对于没有纳入排序的列也可以实现把数据倒转过来的效果(Collecions.reverse实现)。不过有一个地方还可简化下,那就是那个看起来比较长的compareTo方法,只要传入的排序列与java对象的属性列名相同,就可以通过反射的方式来简化,如:
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;
	}

上面的代码用到了两个commons.lang下的工具类,不过代码相对以前的来说,简化了不少,而且不受字段多少影响,看起来舒服多了。每次解决了棘手的问题后总会有不少的收获,虽然过程比较痛苦,毕竟项目是需要进度的,谁敢顶着压力来研究这些呢,只能在有空的时候才来优化。

(2012.1.29):最近偶尔想起,这是一种典型的该使用Comparator而不是Comparable的场合。
分享到:
评论

相关推荐

    v-for根据某字段排序

    v-for根据某字段进行排序显示,方法比较灵活,可嵌入任何系统,不用依赖包,懂点vue基础的人都会用

    C# List OrderBy 动态多字段排序

    本篇文章将深入探讨如何在C#中使用`OrderBy`方法进行动态多字段排序。 首先,了解`OrderBy`的基本用法。`OrderBy`方法接收一个委托作为参数,这个委托定义了排序的规则。在单字段排序中,我们通常使用Lambda表达式...

    js实现点击table表头字段,根据字段排序例子

    在JavaScript中实现点击表格(Table)表头进行字段排序是一种常见的功能需求,特别是在网页数据展示时,用户往往希望可以通过点击列头对数据进行升序或降序排列。本示例将详细讲解如何通过JavaScript实现这一功能。 ...

    C# IList多字段排序

    本篇将详细讲解如何在C#中使用`IList&lt;T&gt;`实现多字段排序。 首先,我们需要了解C#中的排序基础。在C#标准库中,`System.Linq`命名空间提供了强大的排序功能,包括`OrderBy()`和`ThenBy()`方法。这两个方法可以用于...

    OrderByInterceptor,配合PageHelper实现字段排序插件

    OrderByInterceptor,配合PageHelper实现字段排序插件,前端传入要排序的字段和排序规则,插件自动将实体字段映射成数据库字段,不用设置表明前缀。插件通过ResultMap或ResultType读取映射关系,若没有设置,则根据...

    PHP二维数根据字段组排序

    根据二维数组中的某一个字段,进行升序,或者降序的排序。从而减少数据库的压力

    JavaScript数据根据字段值分组排序

    JavaScript数据排序,根据数据中的字段,自定义排序方式,实现数据根据不同的字段值分组显示

    List&lt;map&gt;多字段组合排序

    List,List, Object&gt;&gt;,多字段组合排序。提供一个简易的思路,如果需要进行参考。

    Hibernate中对表某个字段排序

    Hibernate中对表某个字段排序,直接在配置里面实现排序功能。

    jquery 分布 字段排序

    在处理表格数据时,字段排序是常见的需求,尤其是在动态加载或通过Ajax获取数据的情况下。jQuery与Ajax的结合可以实现这种分布式的、基于用户交互的排序功能。 在标题"jquery 分布 字段排序"中,"分布"可能指的是...

    多维数组让数组根据某个字段的大小排序

    ### 多维数组根据某个字段大小排序的知识点详解 在处理数据时,我们经常会遇到需要对数据进行排序的情况。特别是当数据存储在一个多维数组中时,如何有效地根据某一特定字段来对整个数组进行排序变得尤为重要。下面...

    根据JSONArray中给定字段排列顺序

    给出提前排序的数组,jsonArray中字段根据数组顺序重新排序。

    帆软:排序问题(通过帆软设置或者sql排序)

    2. **多字段排序**:在`ORDER BY`后可列出多个字段,通过逗号隔开,先按第一个字段排序,若相同则按第二个字段,以此类推。例如,`ORDER BY column1 ASC, column2 DESC`。 3. **动态排序**:在SQL中,还可以使用`...

    解决Sqlite中文排序问题(网页)

    这样,表中的`name`字段将以拼音顺序进行排序。 4. 考虑兼容性和性能: 自定义Collation可能会对性能产生影响,特别是在大数据量的表上。因此,在实际应用中,需要权衡排序的准确性和性能。如果性能成为问题,可以...

    java 大文件 多字段排序

    在Java编程中,处理大文件并进行多字段排序是一项挑战性的任务,特别是在内存有限的情况下。以下将详细讲解如何实现这个目标。 首先,我们要理解大文件排序的基本原理。当文件太大无法一次性加载到内存时,我们需要...

    基于JavaScript实现Json数据根据某个字段进行排序

    下面是一个实现JSON数据根据某个字段排序的函数示例: ```javascript function jsonSort(array, field, reverse) { // 检查输入是否有效 if(array.length || !field || typeof array[0] !== "object") return ...

    java集合某个字段按照中文拼音排序.docx

    Java集合某个字段按照中文拼音排序是Java开发中经常遇到的问题。对Java集合中的某个字段按照中文拼音排序可以使用多种方法,本文将介绍两种常见的方法。 方法一:使用Comparable接口 在Java中,我们可以使用...

    PB数据窗口的排序

    PB支持多级排序,可以先按一个字段排序,再按照另一个字段排序。在设计时,可以通过为每个字段设置优先级来实现。在代码中,可以通过连续调用`SetSort`方法添加更多的排序级别。 4. **自定义排序**:PB还允许创建...

    List数据字段排序不关注数据库,直接排序

    - **多字段排序**: 对于复杂的数据结构,可以根据多个字段进行排序。 - **数据清洗**: 在处理数据前,先进行排序以便更容易发现异常值或规律。 #### 总结 通过这种方式,我们可以在 Java 中轻松地对 List 集合中的...

Global site tag (gtag.js) - Google Analytics