java - solr按照拼音首字母排序
问题描述
有个标题字段,想按照拼音首字母排序,在solr方法里有一个方法
params.setSort('title',ORDER.asc);//排序字段,正序还是倒序
但这样设置好像结果不是我想要的,我想要的结果如下:序号 标题 首字母1 阿 a2 国 g3 人 r4 中 z
在sql语句里能按照拼音首字母排序,我想知道在solr里能按照拼音首字母排序么?要怎么做,求指导???
问题解答
回答1:你自己新建立一个以“title首字母“为值的新字段作为field不就行了吗,一般来说实际应用中都以自定义的字段作为排序条件
回答2:有个比较简单的做法,如下:
List<String> strs = new ArrayList<>();strs.add('中');strs.add('啊');strs.add('坎');strs.add('哈');strs.add('少');strs.add('发');strs.add('顶');strs.add('擦');strs.add('鹅');strs.add('巴');// 排序strs.sort(Collator.getInstance(Locale.CHINA));// 打印strs.forEach(System.out::println);
结果
啊 // A巴 // B擦 // C顶 // D鹅 // E发 // F哈 // H坎 // K少 // S中 // Z
还可以使用pinyin4j来进行更复杂的排序
相关文章:
1. 编辑成功不显示弹窗2. 哭辽 求大佬解答 控制器的join方法怎么转模型方法3. Navicat for mysql 中以json格式储存的数据存在大量反斜杠,如何去除?4. mysql - 数据库表中,两个表互为外键参考如何解决5. mysql储存json错误6. mysql - 怎么生成这个sql表?7. mysql - 表名称前缀到底有啥用?8. sql语句 - 如何在mysql中批量添加用户?9. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE语法实现存在即更新应该使用哪个标签?10. 怎么php怎么通过数组显示sql查询结果呢,查询结果有多条,如图。
