代码如下:
Collections.sort(list,new Comparator<自动对象ProductofferingTypeInfo >() {
@Override
public int compare(ProductofferingTypeInfo o1,
ProductofferingTypeInfo o2) {
// TODO Auto-generated method stub
Comparator<Object> com = Collator.getInstance(java.util.Locale.CHINA);
return com.compare(o1.getName(), o2.getName());
}
});
上面是参考博客: https://blog.csdn.net/qq_34787830/article/details/83828317
下面是我项目中的应用
这个result是我的返回结果集
List<UserInfo4App> result = new ArrayList<>();
//业务处理
UserInfo4App 里面的字段
@ApiModelProperty("用户名")
private String userName;
@ApiModelProperty("用户真实姓名")
private String realName;
@ApiModelProperty("用户头像文件uuid")
private String portraitUuid;
@ApiModelProperty("手机")
private String mobile;
@ApiModelProperty("邮箱")
private String email;
@ApiModelProperty("职业")
private String career;
@ApiModelProperty("单位名称")
private String unitName;
@ApiModelProperty("0 显示; 1 隐藏")
private Integer display;
@ApiModelProperty("项目名")
private String projectName;
上面的注解不知道的不用管那是swagger的注解
集合处理如下:
按照用户的真实姓名按照首字母排序
result.sort((o1, o2) -> {
Comparator<Object> com = Collator.getInstance(Locale.CHINA);
return com.compare(o1.getRealName(), o2.getRealName());
});
需要注意的是这样处理只是因为实在没办法了,一般排序都是我们在数据库查出来的顺序,对于数据查询按照首字母排序也是可以做到的,查询sql如下:
select*FROM user ORDER BY convert(realName using gbk) ;