忽然 项目中遇到一个问题,就是数据库因为某些原因,只能查出数据,不能排序,因为需要用java对属性进行排序
所以只能手动写了一个,代码如下:
import java.lang.reflect.Method;
import java.math.BigDecimal;
import java.text.Collator;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
import java.util.Locale;
public class SortList<T> {
private Class<T> classType;
public SortList(Class<T> classType){
this.classType = classType;
}
public List<T> getSortList(List<T> list,final String sortFile,final String sortTYpe){
Collections.sort(list, new Comparator<T>() {
@Override
public int compare(T o1, T o2) {
try {
Method method = classType.getMethod("get" + sortFile.substring(0,1) + sortFile.substring(1));
if(method.invoke(o1) == null || method.invoke(o2) == null){
return 0;
}
Collator collator = Collator.getInstance(Locale.CHINA);
String result1 = method.invoke(o1).toString();
String result2 = method.invoke(o2).toString();
if(method.getReturnType().getSimpleName().equals("String")){
if("ASC".equals(sortTYpe.toUpperCase())){
return collator.compare(result1, result2);
}
return -1*collator.compare(result1, result2);
}else{
if("ASC".equals(sortTYpe.toUpperCase())){
return new BigDecimal(result1).compareTo(new BigDecimal(result2));
}
return new BigDecimal(result2).compareTo(new BigDecimal(result1));
}
} catch (Exception e) {
e.printStackTrace();
}
return 0;
}
});
return list;
}
}
这是什么格式,不好用,不能换行,那就写到这