根据中文名字首字母进行分组

第一步:mysql 按中文名字首字母排序  

第二步:循环列表,提取中文首字母

第三步:根据列表首字母进行分组

#mysql 按中文名字首字母排序

ORDER BY CONVERT ( 名字字段 USING gbk ) COLLATE gbk_chinese_ci  ASC

通过mysql将名字进行排序后,可采用java PinyinHelper获取首字母,循环列表,调用下面的方法,将获取名字的首字母设置到对应实体中,然后根据首字母进行分组

# 循环列表,提取中文首字母

package com.core.PinYinUtils;

import net.sourceforge.pinyin4j.PinyinHelper;
import org.apache.commons.lang3.StringUtils;

public class PinYinUtils{
    /**
     * 获取姓名首字母
     * @param name
     * @return 拼音首字母大写
     */
    public static String getNamePinYinHeaderChar(String name){
        String convert = "";
        if(StringUtils.isNotBlank(name)){
            char word = name.charAt(0);
            String[] pinYinArray = PinyinHelper.toHanyuPinyinStringArray(word);
            if ( pinYinArray != null ){
                convert += pinYinArray[0].charAt(0);
            }
        }
        return convert.toUpperCase();
    }


}


 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值