mysql数据库java端查询List的排行排序方法
mysql数据库java端查询List的排名排序方法
Mysql好像不提供排名函数.
网络上的其他什么方法好像可以排序,
也有些对于同分数算名次的处理不够好.
正好工程里有写的排序list (SortListTools)
就在它之上进行了一下扩展.
排序+算名词.其实很简单的.
一般sql查询出来的结果格式为:
list:{[map][map][map][map][map]....}
针对map的某一列排名操作.
rankList方法为传入要排序的list,设置排序列,设置输出名词列.
返回就是排序之后的List.
Mysql好像不提供排名函数.
网络上的其他什么方法好像可以排序,
也有些对于同分数算名次的处理不够好.
正好工程里有写的排序list (SortListTools)
就在它之上进行了一下扩展.
排序+算名词.其实很简单的.
一般sql查询出来的结果格式为:
list:{[map][map][map][map][map]....}
针对map的某一列排名操作.
rankList方法为传入要排序的list,设置排序列,设置输出名词列.
返回就是排序之后的List.
/** * * 这里填写类说明 * @author Juz * Mar 30, 2012 */ @Deprecated public class SortListTools implements Comparator{ private String key; //property public void doSortkey (String key) { this.key = key; } public int compare(Object arg0, Object arg1) { Map m1 = (Map) arg0; Map m2 = (Map) arg1; int flag = 0; float id1 = Float.parseFloat(m1.get(key).toString()); float id2 = Float.parseFloat(m2.get(key).toString()); if ( id2 > id1) { flag = 1; }else if (id1 < id2) { flag = -1; } return flag; } }
/** * List指定列排名. * @param liinfo list:{[map][map][map]....} * @param string key 指定排序map的key * @param string minckey 指定输出排序的key * @return List * @author Juz */ public List rankList(List liinfo, String key, String minckey) { // TODO Auto-generated method stub int thisv = 1; int nextv = 0; float sscore =0; float tscore =0; Map thism =null; Map nextm = null; SortListTools st = new SortListTools(); st.doSortkey(key); Collections.sort(liinfo, st); for(int i=0;i<liinfo.size();i++){ ((Map)liinfo.get(i)).put(minckey, i+1); } for(int i=0;i<liinfo.size();i++){ if(i<liinfo.size()-1){ thism = (Map)liinfo.get(i); thisv = Integer.parseInt(thism.get(minckey).toString()); sscore = Float.parseFloat(thism.get(key).toString()); nextm = (Map)liinfo.get(i+1); tscore = Float.parseFloat(nextm.get(key).toString()); if(sscore-tscore<0.0001){ nextm.put(minckey, thisv); }else{ nextm.put(minckey, thisv+1); } } } return liinfo; }