solr 7.0 与spring-data 3.0整合 --(4)投影及排序

往往为了利于检索,solr的schema中会有大量的字段,但是提交到客户端并不会把所有的字段信息都返回,这时候只会投影部分字段信息。

例如,完整的结构如下:

"data": [
    {
      "resId": "1713074",
      "musicId": "1462975",
      "musicName": "말해버리면 (如果说出来的话)",
      "areaName": "其他",
      "typeId": 4,
      "typeName": "MV",
      "singerName": "안녕의 온도",
      "listenNumber": 438,
      "singerTypeName": "未知",
      "publicTime": "2018-5-8",
      "resName": "말해버리면 (如果说出来的话)",
      "resNamePy": "말해버리면 (RGSCLDH)",
      "resSingerPy": "안녕의 온도(WHDWD)",
      "picture": "http://puui.qpic.cn/qqvideo_ori/0/g0026pq44za_496_280/0",
      "tags": "地区,主题,年代,2018",
      "keywords": [
        "말해버리면 (如果说出来的话)",
        "其他",
        "MV",
        "안녕의 온도",
        "未知",
        "2018-5-8",
        "地区,主题,年代,2018"
      ]
    }
  ],

但是我们只想返回给客户端:

"data": [
    {
      "musicId": "1462975",
      "musicName": "말해버리면 (如果说出来的话)",
      "typeId": 4,
      "singerName": "안녕의 온도",
      "publicTime": "2018-5-8",
      "picture": "http://puui.qpic.cn/qqvideo_ori/0/g0026pq44za_496_280/0",
    }
  ],

这时就需要用到投影(projection)了。

投影

CustomMusicRepository接口中增加:

public ScoredPage<Music> searchByNameProjection(String searchName, long pageIndex, int pageSize);

MusicRepositoryImpl实现:

@Override
public ScoredPage<Music> searchByNameProjection(String searchName, long pageIndex, int pageSize) {
    String[] words = searchName.toUpperCase().split(" ");
    String[] contidionFields = new String[]{Music.FIELD_SONG_NAME, Music.FIELD_SINGER_NAME};
    Criteria conditions = createSearchConditions(contidionFields, words);
    SimpleQuery search = new SimpleQuery(conditions);

    // 投影
    search.addProjectionOnField(Music.FIELD_SONG_NAME);
    search.setOffset(pageIndex);
    search.setRows(pageSize);
    ScoredPage<Music> page = solrTemplate.queryForPage(Music.CORE_NAME, search, Music.class);
    return page;
}

以上代码将songName加入到投影中,那么输出就只有songName才会有值,其余字段均为null。

测试代码:

@Test
public void searchByNameProjection() {
    ScoredPage<Music> musicList = musicRepository.searchByNameProjection("刘德华", 0, 10);
    for (Music music : musicList.getContent()) {
        System.out.println(music);
    }
}

结果如下:

com.ali.model.Music@64a8c844[resId=<null>,songId=<null>,songName=《追龙》持续超车 刘德华身兼化妆师搬运工,singerName=<null>,keywords=<null>]
com.ali.model.Music@3f6db3fb[resId=<null>,songId=<null>,songName=情深的一句,singerName=<null>,keywords=<null>]
com.ali.model.Music@52de51b6[resId=<null>,songId=<null>,songName=无心快意,singerName=<null>,keywords=<null>]
com.ali.model.Music@18c5069b[resId=<null>,songId=<null>,songName=刘德华,singerName=<null>,keywords=<null>]

排序

排序比较简单,将上面的方法改造一下,加入排序:

 @Override
public ScoredPage<Music> searchByNameProjection(String searchName, long pageIndex, int pageSize) {
    String[] words = searchName.toUpperCase().split(" ");
    String[] contidionFields = new String[]{Music.FIELD_SONG_NAME, Music.FIELD_SINGER_NAME};
    Criteria conditions = createSearchConditions(contidionFields, words);
    SimpleQuery search = new SimpleQuery(conditions);

    Sort sort = new Sort(Sort.Direction.DESC, Music.FIELD_SONG_ID);
    search.addSort(sort);
    
    search.addProjectionOnField(Music.FIELD_SONG_NAME);
    search.setOffset(pageIndex);
    search.setRows(pageSize);
    ScoredPage<Music> page = solrTemplate.queryForPage(Music.CORE_NAME, search, Music.class);
    return page;
}
执行上面代码,返回结果即会按照songId 倒序排列。
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,169评论 19 139
  • 一.简介 Solr是一个独立的企业级搜索应用服务器,它对外提供类似于Web-service的API接口。用户可以通...
    泰安青年阅读 9,151评论 0 37
  • 今天小鸡在散步的时候,遇到了大灰狼。大灰狼要吃小鸡,小鸡就连忙跑啊跑,跑进了一家书店——“神奇书店”。 ...
    Happy妈977阅读 3,916评论 0 0
  • “我们,就这样吧!” “好” 我说出那句话的时候我的内心早已湿润,记得这时,天气晴朗,阳光正好。 我们的心里都有过...
    振翅太平洋阅读 2,726评论 0 0
  • 无论什么时候 我都愿意 做真实的自己 不作做 这样子活着 自在又舒服 我也懒得去模仿别人 别人就由别人去做好了 每...
    雪莉诗话阅读 2,905评论 16 28

友情链接更多精彩内容