java对mysql排序,mysql数据库java端查询List的排行排序方法

mysql数据库java端查询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

* @returnList

* @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

((Map)liinfo.get(i)).put(minckey, i+1);

}

for(int i=0;i

if(i

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;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值