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排序了

 

但是我现在得项目用的是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());
            }
        });

页面效果 

 

 

数据库数据得存储顺序

 

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值