目录
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());
}
});
页面效果
数据库数据得存储顺序