欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

springboot整合solr的方法詳解

 更新時(shí)間:2019年08月19日 16:06:43   作者:Leon_W  
這篇文章主要介紹了springboot整合solr的方法詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

這一篇寫一下springboot整合solr,代碼已經(jīng)上傳到github,傳送門。

1、新建core并配置schema

solr create -c "book_core" ,配置分詞器并且field類型定義為分詞器類型。

<fieldType name="ik_word" class="solr.TextField">
   <analyzer type="index">
     <tokenizer class="org.wltea.analyzer.lucene.IKTokenizerFactory" useSmart="false" conf="ik.conf"/>
     <filter class="solr.LowerCaseFilterFactory"/>
   </analyzer>
   <analyzer type="query">
     <tokenizer class="org.wltea.analyzer.lucene.IKTokenizerFactory" useSmart="true" conf="ik.conf"/>
     <filter class="solr.LowerCaseFilterFactory"/>
   </analyzer>
  </fieldType>

   <!-- 自定義添加filed -->
  <field name="description" type="ik_word" indexed="true" stored="true"/>

配置完畢后啟動(dòng)solr。

2、相關(guān)配置

配置maven

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-solr</artifactId>
</dependency>

配置application.properties相關(guān)solr的內(nèi)容

# solr配置
spring.data.solr.host=http://localhost:8983/solr/book_core

如果想同時(shí)使用好幾個(gè)core,通過HttpSolrClient solrClient = new HttpSolrClient(url);構(gòu)造出對(duì)應(yīng)core的solrClient進(jìn)行相關(guān)操作。

3、solr增刪改查

3.1、新增實(shí)體

@SolrDocument(solrCoreName = "book_core")
public class Book {

  @Id
  @Field
  private String id;

  @Field
  private String description;

  public String getId() {
    return id;
  }

  public void setId(String id) {
    this.id = id;
  }

  public String getDescription() {
    return description;
  }

  public void setDescription(String description) {
    this.description = description;
  }
}

在這里要說明一下 實(shí)體類上的注解@field和@SolrDocument 是為了QueryResponse.getBeans()能轉(zhuǎn)化成相關(guān)實(shí)體類,不然無法識(shí)別。

3.2增刪改

@Autowired
  SolrClient solrClient;

  @Override
  public void add(Book book) {
    SolrInputDocument document = new SolrInputDocument();
    document.setField("id",book.getId());
    document.setField("description",book.getDescription());
    try {
      solrClient.add(document);
      solrClient.commit();
    } catch (SolrServerException e) {
      e.printStackTrace();
    } catch (IOException e) {
      e.printStackTrace();
    }
  }

  @Override
  public void delete(String query) {
    try {
      solrClient.deleteByQuery(query);
      solrClient.commit();
    } catch (SolrServerException e) {
      e.printStackTrace();
    } catch (IOException e) {
      e.printStackTrace();
    }
  }

  @Override
  public Book update(Book book) {
    try {
      solrClient.addBean(book);
      solrClient.commit();
    } catch (IOException e) {
      e.printStackTrace();
    } catch (SolrServerException e) {
      e.printStackTrace();
    }
    return book;
  }

增加刪除修改都差不多,增加和修改可以通過add(SolrInputDocument)和addBean,根據(jù)主鍵是否存在來判斷是新增還是修改,刪除可以通過主鍵或者條件進(jìn)行刪除。增刪改之后一定要記得commit!

主鍵是在schema中配置的,默認(rèn)有 id字段做主鍵,也可以自定義主鍵,在schema中配置。

通過add方法加了幾個(gè)demo后,可以在solr管理頁面的查詢出查看添加的內(nèi)容

3.3查詢

查詢則通過SolrQuery入?yún)⑦M(jìn)行查詢

@Override
  public List<Book> queryAll() {
    List<Book> bookList = new ArrayList<Book>();
    SolrQuery solrQuery = new SolrQuery();
    solrQuery.setQuery("*:*");
    try {
      QueryResponse queryResponse = solrClient.query(solrQuery);
      if (queryResponse != null){
        bookList = queryResponse.getBeans(Book.class);
      }
    } catch (SolrServerException e) {
      e.printStackTrace();
    } catch (IOException e) {
      e.printStackTrace();
    }
    return bookList;

同時(shí)我寫了一個(gè)jsp頁面來展示查詢結(jié)果。

到此,增刪改查的基本操作都已經(jīng)實(shí)現(xiàn)了,更多高級(jí)用法可以參考官方api文檔。

4、高亮

一開始在嘗試使用高亮?xí)r發(fā)現(xiàn)無法起作用,排查后發(fā)現(xiàn)高亮是在QueryResponse中的另一個(gè)結(jié)果集的。

QueryResponse.getHighlighting()

取出來的字段值為自定義前綴后綴拼接具體字段值。

@Override
  public List<Book> query(String query) {
    List<Book> bookList = new ArrayList<Book>();
    SolrQuery solrQuery = new SolrQuery();
    //設(shè)置默認(rèn)搜索的域
    solrQuery.set("df", "description");
    solrQuery.setQuery(query);
    //高亮顯示
    solrQuery.setHighlight(true);
    //設(shè)置高亮顯示的域
    solrQuery.addHighlightField("description");
    //高亮顯示前綴
    solrQuery.setHighlightSimplePre("<font color='red'>");
    //后綴
    solrQuery.setHighlightSimplePost("</font>");
    try {
      QueryResponse queryResponse = solrClient.query(solrQuery);
      if (queryResponse == null){
        return null;
      }
      SolrDocumentList solrDocumentList = queryResponse.getResults();
      if (solrDocumentList.isEmpty()){
        return null;
      }
      //獲取高亮
      Map<String, Map<String, List<String>>> map = queryResponse.getHighlighting();
      for (SolrDocument solrDocument : solrDocumentList){
        Book book;
        List<String> list = map.get(solrDocument.get("id")).get("description");
        if (!CollectionUtils.isEmpty(list)){
          solrDocument.setField("description",list.get(0));
        }
        String bookStr = JSONUtil.toJSON(solrDocument);
        book = JSON.parseObject(bookStr,Book.class);
        bookList.add(book);
      }
    } catch (SolrServerException e) {
      e.printStackTrace();
    } catch (IOException e) {
      e.printStackTrace();
    }
    return bookList;
  }

頁面展示如下:

搜索框分詞之后,搜索出來的帶有高亮的值。

增刪改查最基本的應(yīng)用就差不多了,更高級(jí)的代碼請(qǐng)查看官方api文檔。上文中所有代碼都上傳至github,傳送門。

相關(guān)文章

  • Java讀寫txt文件代碼實(shí)例

    Java讀寫txt文件代碼實(shí)例

    這篇文章主要給大家介紹了關(guān)于Java讀寫txt文件的相關(guān)資料,近期處理的數(shù)據(jù)規(guī)模比較大,正好又是統(tǒng)計(jì)合并的事情,想著借助excel就可以完成了,然后就了解了下java讀取excel的事情,需要的朋友可以參考下
    2023-09-09
  • Java Web中解決路徑(絕對(duì)路徑與相對(duì)路徑)問題

    Java Web中解決路徑(絕對(duì)路徑與相對(duì)路徑)問題

    這篇文章主要介紹了Java Web中解決路徑問題的相關(guān)資料,java 文件路徑有絕對(duì)路徑與相對(duì)路徑,這里提供了幾種方法解決所有路徑問題,需要的朋友可以參考下
    2017-01-01
  • SpringMVC攔截器配置及運(yùn)行流程解析

    SpringMVC攔截器配置及運(yùn)行流程解析

    這篇文章主要介紹了SpringMVC攔截器配置及運(yùn)行流程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-06-06
  • 關(guān)于訪問后端接口報(bào)404錯(cuò)誤問題的解決方法(全網(wǎng)最細(xì)!)

    關(guān)于訪問后端接口報(bào)404錯(cuò)誤問題的解決方法(全網(wǎng)最細(xì)!)

    404頁面的出現(xiàn)會(huì)降低用戶體驗(yàn),那么導(dǎo)致404頁面出現(xiàn)的原因是什么呢?這篇文章主要給大家介紹了關(guān)于訪問后端接口報(bào)404錯(cuò)誤問題的解決方法,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-04-04
  • 使用SpringAOP實(shí)現(xiàn)公共字段填充功能

    使用SpringAOP實(shí)現(xiàn)公共字段填充功能

    在新增員工或者新增菜品分類時(shí)需要設(shè)置創(chuàng)建時(shí)間、創(chuàng)建人、修改時(shí)間、修改人等字段,在編輯員工或者編輯菜品分類時(shí)需要設(shè)置修改時(shí)間、修改人等字段,這些字段屬于公共字段,本文將給大家介紹使用SpringAOP實(shí)現(xiàn)公共字段填充功能,需要的朋友可以參考下
    2024-08-08
  • Java排序算法總結(jié)之插入排序

    Java排序算法總結(jié)之插入排序

    這篇文章主要介紹了Java排序算法總結(jié)之插入排序,較為詳細(xì)的分析了插入排序的原理與java實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2015-05-05
  • Spring Boot日志技術(shù)logback原理及配置解析

    Spring Boot日志技術(shù)logback原理及配置解析

    這篇文章主要介紹了Spring Boot日志技術(shù)logback原理及用法解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-07-07
  • 基于rocketmq的有序消費(fèi)模式和并發(fā)消費(fèi)模式的區(qū)別說明

    基于rocketmq的有序消費(fèi)模式和并發(fā)消費(fèi)模式的區(qū)別說明

    這篇文章主要介紹了基于rocketmq的有序消費(fèi)模式和并發(fā)消費(fèi)模式的區(qū)別說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • Java將字符串寫入文本文件代碼示例

    Java將字符串寫入文本文件代碼示例

    這篇文章主要介紹了Java將字符串寫入文本文件代碼示例,具有一定借鑒價(jià)值,需要的朋友可以參考下。
    2017-12-12
  • java讀取word文檔,提取標(biāo)題和內(nèi)容的實(shí)例

    java讀取word文檔,提取標(biāo)題和內(nèi)容的實(shí)例

    這篇文章主要介紹了java讀取word文檔,提取標(biāo)題和內(nèi)容的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10

最新評(píng)論