java如何对List集合中的姓名进行排序

目录

1.用数据库进行排序(除SQLite外)

2.用Java对其排序


1.用数据库进行排序(除SQLite外)

由于一般数据库编码大都为utf-8 ,他的排序方式为按英文字母规则排序 "a,b,c..... "

但是我们要对中文姓名排序得时候必须转换为GBK编码才可以,那么怎么转化呢

在MySQL中提供了函数CONVERT() ,该函数可用来获取一个类型的值

该函数的使用方式为 CONVERT(字段 USING GBK)

select nickname from user order by CONVERT(nickname USING GBK) asc;

这时就是按首字母 A-Z排序了

java如何对List集合中的姓名进行排序_第1张图片 

但是我现在得项目用的是SQLite,用这个函数并不能运行,

错误得大体意思就是USING这个地方,有问题无法识别

java如何对List集合中的姓名进行排序_第2张图片

2.用Java对其排序

 所以我最后用得是工具类Collections得sort方法,我写在了service里

这样你的lists集合就已经改变了

List lists = developMapper.getDeveiopList(developDTO);
        Collections.sort(lists, new Comparator() {
            @Override
            public int compare(DevelopDTO o1, DevelopDTO o2) {
                //排序规则:按照汉字拼音首字母排序
                Comparator com = Collator.getInstance(java.util.Locale.CHINA);
                return com.compare(o1.getName(), o2.getName());
            }
        }); 
   
  

页面效果 

 java如何对List集合中的姓名进行排序_第3张图片

 

数据库数据得存储顺序

java如何对List集合中的姓名进行排序_第4张图片

 

你可能感兴趣的:(java,list,排序算法)