springboot整合solr的方法詳解
這一篇寫一下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"/>
配置完畢后啟動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
如果想同時使用好幾個core,通過HttpSolrClient solrClient = new HttpSolrClient(url);構(gòu)造出對應(yīng)core的solrClient進行相關(guān)操作。
3、solr增刪改查
3.1、新增實體
@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;
}
}
在這里要說明一下 實體類上的注解@field和@SolrDocument 是為了QueryResponse.getBeans()能轉(zhuǎn)化成相關(guān)實體類,不然無法識別。
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ù)主鍵是否存在來判斷是新增還是修改,刪除可以通過主鍵或者條件進行刪除。增刪改之后一定要記得commit!
主鍵是在schema中配置的,默認有 id字段做主鍵,也可以自定義主鍵,在schema中配置。
通過add方法加了幾個demo后,可以在solr管理頁面的查詢出查看添加的內(nèi)容

3.3查詢
查詢則通過SolrQuery入?yún)⑦M行查詢
@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;
同時我寫了一個jsp頁面來展示查詢結(jié)果。

到此,增刪改查的基本操作都已經(jīng)實現(xiàn)了,更多高級用法可以參考官方api文檔。
4、高亮
一開始在嘗試使用高亮?xí)r發(fā)現(xiàn)無法起作用,排查后發(fā)現(xiàn)高亮是在QueryResponse中的另一個結(jié)果集的。
QueryResponse.getHighlighting()
取出來的字段值為自定義前綴后綴拼接具體字段值。
@Override
public List<Book> query(String query) {
List<Book> bookList = new ArrayList<Book>();
SolrQuery solrQuery = new SolrQuery();
//設(shè)置默認搜索的域
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)用就差不多了,更高級的代碼請查看官方api文檔。上文中所有代碼都上傳至github,傳送門。
相關(guān)文章
關(guān)于訪問后端接口報404錯誤問題的解決方法(全網(wǎng)最細!)
404頁面的出現(xiàn)會降低用戶體驗,那么導(dǎo)致404頁面出現(xiàn)的原因是什么呢?這篇文章主要給大家介紹了關(guān)于訪問后端接口報404錯誤問題的解決方法,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2023-04-04
Spring Boot日志技術(shù)logback原理及配置解析
這篇文章主要介紹了Spring Boot日志技術(shù)logback原理及用法解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-07-07
基于rocketmq的有序消費模式和并發(fā)消費模式的區(qū)別說明
這篇文章主要介紹了基于rocketmq的有序消費模式和并發(fā)消費模式的區(qū)別說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-06-06

