0
点赞
收藏
分享

微信扫一扫

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

E_topia 2022-03-11 阅读 96

目录

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

2.用Java对其排序


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

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

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

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

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

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

 

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

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

2.用Java对其排序

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

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

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

页面效果 

 

 

数据库数据得存储顺序

 

举报

相关推荐

0 条评论