mysql 取得行号后再排序

Posted 鹏鹏进阶

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql 取得行号后再排序相关的知识,希望对你有一定的参考价值。

一.理论准备

        Map是键值对的集合接口,它的实现类主要包括:HashMap,TreeMap,Hashtable以及LinkedHashMap等。

        TreeMap:基于红黑树(Red-Black tree)的 NavigableMap 实现,该映射根据其键的自然顺序进行排序,或者根据创建映射时提供的 Comparator 进行排序,具体取决于使用的构造方法。

        HashMap的值是没有顺序的,它是按照key的HashCode来实现的,对于这个无序的HashMap我们要怎么来实现排序呢?参照TreeMap的value排序。

        Map.Entry返回Collections视图。

 

二.key排序

        TreeMap默认是升序的,如果我们需要改变排序方式,则需要使用比较器:Comparator。Comparator可以对集合对象或者数组进行排序的比较器接口,实现该接口的public compare(T o1,To2)方法即可实现排序,如下:

import java.util.Comparator;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;

public class TreeMapTest {
    public static void main(String[] args) {
        Map<String, String> map = new TreeMap<String, String>(
                new Comparator<String>() {
                    public int compare(String obj1, String obj2) {
                        // 降序排序
                        return obj2.compareTo(obj1);
                    }
                });
        map.put("b", "ccccc");
        map.put("d", "aaaaa");
        map.put("c", "bbbbb");
        map.put("a", "ddddd");
        
        Set<String> keySet = map.keySet();
        Iterator<String> iter = keySet.iterator();
        while (iter.hasNext()) {
            String key = iter.next();
            System.out.println(key + ":" + map.get(key));
        }
    }
}

        运行结果如下:

d:aaaaa
c:bbbbb
b:ccccc
a:ddddd

 

三.value排序

        上面例子是对根据TreeMap的key值来进行排序的,但是有时我们需要根据TreeMap的value来进行排序。对value排序我们就需要借助于Collections的sort(List<T> list, Comparator<? super T> c)方法,该方法根据指定比较器产生的顺序对指定列表进行排序。但是有一个前提条件,那就是所有的元素都必须能够根据所提供的比较器来进行比较,如下:

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import java.util.TreeMap;

public class TreeMapTest {
    public static void main(String[] args) {
        Map<String, String> map = new TreeMap<String, String>();
        map.put("a", "ddddd");
        map.put("c", "bbbbb");
        map.put("d", "aaaaa");
        map.put("b", "ccccc");
        
        //这里将map.entrySet()转换成list
        List<Map.Entry<String,String>> list = new ArrayList<Map.Entry<String,String>>(map.entrySet());
        //然后通过比较器来实现排序
        Collections.sort(list,new Comparator<Map.Entry<String,String>>() {
            //升序排序
            public int compare(Entry<String, String> o1,
                    Entry<String, String> o2) {
                return o1.getValue().compareTo(o2.getValue());
            }
            
        });
        
        for(Map.Entry<String,String> mapping:list){ 
               System.out.println(mapping.getKey()+":"+mapping.getValue()); 
          } 
    }
}

        运行结果如下:

d:aaaaa
c:bbbbb
b:ccccc
a:ddddd

 

这个结合mysql取得行号并排序来讲解

package mysqlTest;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import java.util.TreeMap;

public class mysqlTest2 {
	public static void main(String arg[]) {
		try {
			Connection con = null; // 定义一个MYSQL链接对象
			Class.forName("com.mysql.jdbc.Driver").newInstance(); // MYSQL驱动
			con = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/Demo", "root", "root"); // 链接本地MYSQL

			Statement stmt; // 创建声明
			stmt = con.createStatement();

			String str = "Select name,(@rowNum:[email protected]+1) as rowNo,score From mysqlSort,"
					+ "(Select (@rowNum :=0) ) b Order by mysqlSort.score Desc";
			ResultSet res = stmt.executeQuery(str);
			Map<String, Integer> map = new TreeMap<String, Integer>();
			while (res.next()) {
				map.put(res.getString(1), res.getInt(2));

			}
			Map<String, Integer> map1 = new TreeMap<String, Integer>();
			for (Map.Entry<String, Integer> m : map.entrySet()) {
				map1.put(m.getKey(), m.getValue());
			}
			List<Map.Entry<String, Integer>>  list = new ArrayList<Map.Entry<String, Integer>>(map1.entrySet());
			Collections.sort(list, new Comparator<Map.Entry<String, Integer>>() {

				public int compare(Entry<String, Integer> o1, Entry<String, Integer> o2) {
					// TODO Auto-generated method stub
					return o2.getValue()-o1.getValue();
				}
			});
			for (Map.Entry<String, Integer> m : map.entrySet()) {
				System.out.println(m.getKey() + ":" + m.getValue());
			}
			System.out.println("============");
			for (Map.Entry<String, Integer> m : list) {
				System.out.println(m.getKey() + ":" + m.getValue());
			}
		} catch (Exception e) {
			System.out.print("MYSQL ERROR:" + e.getMessage());
		}

	}
}

 

 

 
 

以上是关于mysql 取得行号后再排序的主要内容,如果未能解决你的问题,请参考以下文章

mysql中如何取得某一记录在某一条件排序中的位次

VBA中如何取得行号和列号如何选定这一范围的值

为啥此代码片段返回意外结果?

mysql 分组排序

MYSQL 5.7 获取行号

mysql结果集筛选排序